|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
;除法溢出
assume cs :code
code segment
start :
mov ax ,1000h
mov bh ,1
div bh
mov ax,4c00h
int 21h
code ends
end start
在没有修改0号中断时,在CMD中运行生成的exe(12.exe)文件,显示如下: |
当安装了如下0号中断例程(xiugai2.exe)后
;名称:0号中断处理程序
;功能:使得除法溢出发生时,在屏幕中间显示字符串'Welcome to fishc.com!',然后返回DOS assume cs:code
code segment
start:
mov ax,cs
mov ds ,ax
mov si ,offset do0 ;设置ds:si指向源地址
mov ax ,0
mov es ,ax
mov di ,200h ;设置es:di指向目的地址
mov cx ,offset do0end- offset do0 ;设置cx为传输长度
cld ;设置传输方向为正
rep movsb
mov ax ,0 ;设置中断向量表
mov es ,ax
mov word ptr es:[0*4],200h
mov word ptr es:[0*4+2],0
mov ax ,4c00h
int 21h
do0: jmp short do0start
db "Welcome to Fishc.com!"
do0start:
mov ax , cs
mov ds , ax
mov si ,202H ;设置ds:si指向字符串
mov ax ,0b800h
mov es ,ax
mov di ,12*160+36*2 ;设置es:di指向显存空间的中间位置
mov cx ,21 ;设置cx为字符串的长度
s: mov al ,[si]
mov ah,02h;设置颜色
mov es:[di] ,ax
inc si
add di ,2
loop s
mov ax ,4c00h
int 21h
do0end: nop
code ends
end start
即先在CMD中运行xiugai2.exe,在运行12.exe,显示如下
为什么返回运行12.EXE瞬间闪过后返回DOS没有看到“Welcome to fishc.com!”向'Divide overflow'一样出现
而在CMD中运行xiugai2.exe后,再用DEBUG 调试12.exe却可以看到如图效果
|
|