学习:比较指令

cmp指令:比较

cmp指令,和sub指令的最大的不同点就是影响标志位 不储存结果

1、当前汇编指令为cmp ecx,edx
2、当前ecx寄存器中的地址值为00000000,edx寄存器中的地址值00000001,相当于ecx = ecx-edx
3、单步步过

结果发现ecx寄存器中没有变化

1、当前汇编指令为cmp eax,ecx
2、当前eax寄存器中的地址值为00000001,ecx寄存器中的地址值00000001,相当于 eax = eax-ecx
3、单步步过

结果发现ecx寄存器中没有变化,但是发现Z标志位发生了变化 变为了1,也可以说明了当cmp指令为两个相减为0的时候,那么Z标志位为1

如何进行对字符串的比较呢,这里自己理解的是对寄存器中的地址中的值进行比较比如如下

再进行重新设置EIP然后单步步过,结果如下,发现Z标志位变0,所以大小不一致

同样的,cmp影响的不只是Z标志位,之前S标志位是根据正负数来判断的,这里同样生效
1、当前汇编指令为cmp eax,ecx
2、当前eax寄存器中的地址值为00000000,ecx寄存器中的地址值00000001,相当于 eax = eax-ecx
3、单步步过

结果发现,S标志位为1,因为相减为负数

当然,cmp指令不只是寄存器与寄存器之间,还可以寄存器与地址的值之间,比如:
1、当前汇编指令为cmp eax,[402000]
2、设置地址402000中的值为01
3、单步步过

扫描二维码关注公众号,回复: 8212258 查看本文章

结果Z为1 那么相减结果为0,S为0,那么结果不是负数

猜你喜欢

转载自www.cnblogs.com/zpchcbd/p/12051837.html