23-18

怎么识别指令跳转条件和内存访问

如何识别指令跳转条件

在汇编语言中,跳转指令分为无条件跳转有条件跳转

1. 无条件跳转

这是最简单的一种。它们总是会改变程序的执行流程

  • 指令jmp (Jump)
  • 识别方法:在反汇编代码中,jmp 指令后面通常跟着一个目标地址。它像一个程序里的 goto 语句,直接将控制权转移到另一个位置,没有其他条件

2. 有条件跳转

这些跳转指令依赖于 CPU 的标志寄存器(Flags Register)的状态。标志寄存器中的位(如零标志、符号标志、进位标志等)在执行算术或比较指令后会被设置

  • 指令:有条件跳转指令通常以字母 j 开头,后面跟着一个或两个字母来表示其条件
    • je (Jump if Equal):如果零标志(ZF)为1,则跳转。通常跟在 cmptest 指令之后,用于判断两个值是否相等
    • jne (Jump if Not Equal):如果零标志(ZF)为0,则跳转
    • jg (Jump if Greater):如果大于则跳转(有符号)
    • jl (Jump if Less):如果小于则跳转(有符号)
    • ja (Jump if Above):如果大于则跳转(无符号)
    • jb (Jump if Below):如果小于则跳转(无符号)
  • 识别方法
    1. 寻找前置指令:有条件跳转指令通常紧跟在比较(cmp测试(test指令之后
    2. 分析标志位cmp 指令会执行一次减法操作,但不保存结果,只根据结果设置标志位。test 指令会执行一次逻辑与操作,也不保存结果,同样只设置标志位
    3. 理解逻辑:当看到 cmp eax, ebx 后跟着 je 时,它的逻辑就等同于 C 语言的 if (eax == ebx)