|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
;一个不会溢出的除法运算 ,被除数dword,除数word 结果:dx高16位 ax低16位 cx余数
assume cs:code
stack segment
dw 0,0,0,0,0,0,0,0
stack ends
datasg segment
dw 0,0,0,0,0,0,0,0
datasg ends
code segment
start:
;设置栈段和栈顶指针
mov ax,stack;
mov ss,ax;
mov sp,10h;
;设置数据段空间
mov ax,datasg;
mov ds,ax
mov ax,4240h
mov dx,000fh
mov cx,0ah
call divdw
mov ax,4c00h
int 21h;
divdw:
;首先推导出X/N = int(H/N)*65536 +[rem(H/N)*65536 + L]/N,推导过程在汇编语言附注5,哥这里就不说了。推导过程不是很复杂
mov bx,ax;保存低位数据
;先求第一个除法的值
mov ax,dx;
mov dx,0;
div cx
;商在ax中,也就是int(H/N)的结果。这也就是高位的值,按照要求,把高位的值给dx,但是后面还会需要用到dx,所以先把高位的值保存到数据段
push ax
;余数在dx中,rem(H/N)的值出来了。第2次除法的高位就是rem(H/N),现在求第二个除法的低位L
mov ax,bx;
div cx
;低位商在ax,余数在dx
push ax;
push dx;
;按照要求将结果的高位给dx,低位给ax,余数给cx
pop cx
pop ax
pop dx
ret
code ends
end start;
|
|