汇编 溢出的判断

对于初学汇编语言的初学者来说,是否溢出是一个难点,现总结如下:

执行加法指令ADD:

OF标志位根据操作数的符号及其变化情况来设置:若两个操作数的符号相同,而结果的符号与之相反时,OF=1,否则OF=0。溢出位既然是根据数的符号及其变化来设置的,当然他使用来表示带符号数的溢出的。

 

执行减法指令SUB:

减法的OF位的设置方法为:若两个数的符号相反,而结果的符号与减数的符号相同,则OF=1,除上述情况外OF=0。OF=1说明带符号数的减法运算结果是错误的。

 

求补运算指令NEG:

NEG指令的条件码按求补后的结果设置,只有当操作数为0时,求补运算结果使CF=0,其他情况均为CF=1.所以,只有当字节运算时对-128求补,以及字运算时对-32768求补和双字运算时对-2的31次方求补的情况下OF=1,其他则OF=0。

 

无符号乘法指令MUL:

对于MUL指令,如果乘积的高一半为0,几字节操作的(AH)或字操作的(DX)或双字的(EDX)为0,则CF位和OF位均为0;否则,均为1.

 

带符号数乘法指令IMUL:

对于IMUL指令,如果乘积的高一半是低一半的符号扩展,则CF位和OF位均为0,否则为1.

 

除法指令:

除法指令对所有条件码位均无定义。但是需要注意一个问题,如果字节操作时,被除数的高8位的绝对值》除数的绝对值;或者字操作时,被除数的高16为绝对值》除数的绝对值,则商就会产生溢出。

在8086系统中,这种溢出是由系统直接转入0型中断处理的。为避免这种情况,必要时程序应进行溢出判断及处理。

 

逻辑运算指令:

AND,OR,NOT,XOR,TESTT中,NOT不影响标志位,其他4种指令将使CF位和OF位为0.

 

移位指令:

OF位只有当移位次数CNT=1时,即移动一位的时候才是有效的,否则该位无定义。当CNT=1时,在移位后最高有效位的值发生变化时(原来为0,移位后为1;或原来为1,移位后为0)OF=1,否则值为0.

 

串处理指令:

MOVS,LODS,STOS,INS,OUTS不影响标志位。

 

转移指令:

所有条件转移指令都不影响条件码,JMP也不影响条件码。

 

循环指令:

不影响条件码。

 

子程序:

CALL和RET都不影响条件码

 

  • 6
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
汇编语言中,判断无符号乘法是否溢出可以通过检查乘法结果是否超出了所使用的寄存器的位数来实现。以下是一种常见的方法: 1. 使用无符号乘法指令进行乘法运算。例如,对于x和y两个无符号数进行乘法,可以使用`MUL`指令,将x乘以y的结果存储在结果寄存器中。 2. 检查结果是否超出了所使用的寄存器的位数。如果结果超出了寄存器的位数限制,则说明发生了溢出。 具体的实现方法取决于所使用的汇编语言和处理器架构。下面是一个示例,在x86汇编语言中使用32位无符号乘法(`MUL`指令)进行溢出判断的示例: ```assembly ; 假设x和y分别存储在eax和ebx寄存器中 mov eax, x mov ebx, y mul ebx ; 无符号乘法,结果存储在edx:eax中 ; 检查结果是否溢出 test edx, edx ; 检查edx寄存器的值是否为0 jnz overflow ; 如果edx不为0,则发生了溢出 ; 在这里处理未发生溢出的情况 overflow: ; 在这里处理溢出的情况 ``` 在示例中,使用`MUL`指令进行无符号乘法运算,将结果存储在edx:eax寄存器中。然后,通过检查edx寄存器的值是否为0来判断是否发生了溢出。如果edx寄存器不为0,则说明溢出发生了。根据需要,可以在`overflow`标签处处理溢出情况,或在未发生溢出的情况下执行其他操作。 请注意,具体的实现方法可能因使用的汇编语言和处理器架构而有所不同。上述示例仅作为一种常见的方法,具体实现时请参考相关的汇编语言和处理器架构文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值