汇编cmp指令的用法 大神请进
1个回答
展开全部
举个例子吧:
假设现在AX寄存器中的数是0002H,BX寄存器中的数是0003H。
执行的指令是:CMP
AX,
BX
执行这条指令时,先做用AX中的数减去BX中的数的减法运算。
列出二进制运算式子:
0000
0000
0000
0010
-
0000
0000
0000
0011
_________________________________
(借位1)
1111
1111
1111
1111
所以,运算结果是
0FFFFH
根据这个结果,各标志位将会被分别设置成以下值:
CF=1,因为有借位
OF=0,未溢出
SF=1,结果是负数
ZF=0,结果不全是零
还有AF,
PF等也会相应地被设置。
CMP
比较指令做了减法运算以后,根据运算结果设置了各个标志位。
标志位设置过以后,0FFFFH这个减法运算的结果就没用了,它被丢弃,不保存。
执行过了CMP指令以后,除了CF,ZF,OF,
SF,等各个标志位变化外,其它的数据不变。
对照普通的减法指令
SUB
AX,
BX,它们的区别就在于:
SUB指令执行过以后,原来AX中的被减数丢了,被换成了减法的结果。
CMP指令执行过以后,被减数、减数都保持原样不变。
假设现在AX寄存器中的数是0002H,BX寄存器中的数是0003H。
执行的指令是:CMP
AX,
BX
执行这条指令时,先做用AX中的数减去BX中的数的减法运算。
列出二进制运算式子:
0000
0000
0000
0010
-
0000
0000
0000
0011
_________________________________
(借位1)
1111
1111
1111
1111
所以,运算结果是
0FFFFH
根据这个结果,各标志位将会被分别设置成以下值:
CF=1,因为有借位
OF=0,未溢出
SF=1,结果是负数
ZF=0,结果不全是零
还有AF,
PF等也会相应地被设置。
CMP
比较指令做了减法运算以后,根据运算结果设置了各个标志位。
标志位设置过以后,0FFFFH这个减法运算的结果就没用了,它被丢弃,不保存。
执行过了CMP指令以后,除了CF,ZF,OF,
SF,等各个标志位变化外,其它的数据不变。
对照普通的减法指令
SUB
AX,
BX,它们的区别就在于:
SUB指令执行过以后,原来AX中的被减数丢了,被换成了减法的结果。
CMP指令执行过以后,被减数、减数都保持原样不变。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询