《汇编语言》实验10.2 解决除法溢出问题

实验10.2

关于div指令

div是除法指令,使用div做除法的时候应该注意以下问题:

  1. 除数:有8位和16位两种,在一个reg或内存单元中。
  2. 被除数:默认放在AX或DX和AX中,如果除数为8位,被除数则为16位,默认在AX中存放;如果除数为16位,被除数则为32位,在DX和AX中存放,DX存放高16位,AX存放低16位
  3. 结果:如果除数为8位,则AL存储出发操作的商,AH存储除法操作的余数;如果除数为16位,则AX存储出发操作的商,DX存储出发操作的余数。

除法溢出:我们再用div指令做除法的时候,很可能发生上面的情况:为8位除法,除以1000H,其中8位除法指的是除数为8位,比如处以1H,那么结果1000H很明显在AL中是存储不了的,这时这种错误就叫做除法溢出。

我们应该怎样解决这个问题呢?

assume cs:code,ss:stack

stack segement
    dw 0,0
stack ends

code 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 ax
        mov ax,dx
        mov dx,0
        div cx
        mov bx,ax
        pop ax
        div cx
        mov cx,dx
        mov dx,bx
        ret

code ends
end start

记住,汇编语言说到底就是数据的移动转移,因为地方有限,所以,这里移动一点,那里移动一点。

使用“数据流“的思想,会很好理解的。

我们把结果放在ax中,商放在dx中。
而被除数默认放在ax和dx中,这难免不了移动。

思路解析:

先开始处理dx吧,那么ax放被除数和结果的,那么ax本身的数据就要被移动入栈了,就是push ax
之后应该把要处理的dx放进ax中,但我们要处理的是8位啊,那么dx中还会存在数据,怎么办?当然清零啊!
故有mov ax,dx;mov dx,0
完成之后就可以来进行除法运算,除数在cx中,故div cx。算出来的结果商在ax中,我们还要进行出栈,要快点把它拿开,放到哪里呢?寄存器bx还空闲着,故有mov bx,ax
而之后就可以出栈了pop ax,此时DX还保留着上次的余数呢!
当然啊,因为它是高位哇!余数依然作为这次的高位啊!
这样,我们只要把低位ax提出来,然后再进行除法运算!div cx
结果ax为商,dx为余数,这时dx就是实实在在的余数了。
我们把这些整理一下
mov cx,dx mov dx,bx
这样:cx–最后的余数 dx–高八位的商 ax–低八位的商!

可以看出,所谓汇编语言难理解,是因为你缺乏机器的思维语言,这是你需要明确的,你必须清楚你的数据来自哪里,要干什么,要放哪里,遇到冲突怎么办,相关指令的处理机制,当明白这些时,你切问题都不是问题了!

你要无时无刻牢记你原先存储数据的位置,这点一定要明确!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值