汇编实验十,解决除法溢出的问题divdw

继续吧,人生那么长,总得留下点什么
assume cs:codesg,ss:stack
stack segment
	db 16 dup (0)
stack ends

codesg segment
start:	mov ax,stack
	mov ss,ax
	mov sp,10h 	;栈定义
	
	
	
	mov ax,4240h	;原被除数的低位
	mov dx,000Fh	;原被除数的高位
	mov cx,0Ah	;除数
	call divdw
	mov ax,4c00h
	int 21h

divdw:
	push bx	;保护bx中的值吧
	push ax		;原被除数的低位入栈
	push dx		;将原被除数的高位入栈
	push cx		;将除数入栈
	push dx		;将原被除数的高位入栈
	
	;将原被除数的高位弹出到被除数的低位 即ax
	pop ax
	;被除数的高位置0
	mov dx,0
	;将除数出栈
	pop cx
	;第一个式子int(H/N)的H/N
	div cx
	;存第一个式子的商到bx 因为*65536,即这是结果的高位
	
	mov bx,ax
	
	mov dx,0
	pop ax  	;原被除数的高位送到被除数的低位
	div cx
	;求得的dx作为新被除数的高位
	pop ax		;+L 即新被除数的低位
	div cx
	mov cx,dx	;第二个式子才有余数
	;这是最后的结果
	mov dx,bx
	pop bx    ;恢复bx中的值
	;dx 存结果的高位,ax存结果的低位
	retn

codesg ends
end start
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值