0x03 一些汇编相关的小知识

cmp指令用于比较dest和src两个操作数,并通过比较之后的结果设置C/O/Z标志位

cmp eax,ebx ;如果相等,Z标志位1,否则为0

cmp eax,[404000] ;将eax和404000的dword数据比较并置位.

cmp能修改的三个位:

Z:运算结果为0则该位置1

O:溢出则该位置1

C:进位标志位,有进位就置1


test test dest,src

和and指令一样将两个操作数作与,但它结果保存到deat中。

来自小甲鱼OD调试视频。



然后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指令执行过以后,被减数、减数都保持原样不变。
JMP指令,网友的解答

加上jl指令:实际上只要记住jl指令就是在cmp比较之后(如cmp eax,ebx),如果是eax

je:相等的时候跳转

你可能感兴趣的:(OD调试学习,jmp,汇编,x86)