您的位置:首页 > 其它

汇编实验10-2 解决除法溢出的问题

2015-05-29 21:11 309 查看
代码及注释:

;本程序主要意图为制作一个子程序,实现32位被除数/16位除数因为16位寄存器不够储存
;而产生除法溢出的情况(如FFFFFFFF/1,16位寄存器ax储存不了32位数据)
;子程序的实现过程在书中实验的提示给了算法,在理解的基础上写出程序即可
;以下为程序
assume cs:code,ss:stack
stack segment
db 16 dup (0)
stack ends

code segment
start:
mov ax,stack
mov ss,ax
mov sp,16		;源程序中这条指令没写,无伤大雅,以上为初始化栈指针指向栈底

mov ax,4240h
mov dx,0fh
mov cx,0ah	;ax为32位被除数的低16位数据,dx为高16位数据,cx为16位除数

call divdw

mov ax,4c00h
int 21h
;子程序描述
;名称:divdw
;功能:进行不会产生溢出的除法运算,被除数dword型,除数word型,结果为dword型
;参数:(ax)=被除数低16位、(dx)=被除数高16位、(cx)=除数
;返回:(dx)=结果的高16位、(ax)=结果低16位、(cx)=余数
;实验提示:
;X:被除数
;N:除数
;H:X高16
;L:X低16
;int():描述性运算符,取商
;rem():描述性运算符,取余
;公式:X/N=int(H/N)*65536+[rem(H/N)*65536+L]/N
divdw:
push ax
mov ax,dx
mov dx,0
div cx		;计算H/L,ax中的值为最终结果的高16位(看公式可知)
mov si,ax
mov di,dx
pop ax
div cx		;因为dx保存着H/L的余数,可以做公式后面运算的高16位。
;取出X的低16位
mov cx,dx	;公式后面运算结果的余数给cx
mov dx,si	;公式前面的运算结果之前保存给si了


代码截图及结果:







小结:

主要是算法高端~~我没起啥作用

必要的东西都写在上面了。

加油把!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: