常用x86汇编指令整理

    X86汇编指令很多,如果不是专业用汇编语言开发程序,完全没有必要记忆那么多指令,若只用于调试软件只要记住常用的指令就可以了,遇到不常用的到时候先查也来得及,不影响工作。

    MOV

    示例:MOV EAX,ECX  含义:EAX=ECX  解释:将ECX的值储存到EAX

    ADD

    示例:ADD EAX,ECX  含义:EAX=EAX+ECX 解释:将EAX的值加上ECX的值

    SUB

    示例:SUB EAX,ECX  含义:EAX=EAX-ECX 解释:将EAX的值减去ECX的值

    INC

    示例:INC EAX  含义:EAX+1  解释:将 EAX 的值加 1

    DEC

    示例:DEC EAX  含义:EAX-1  解释:将 EAX 的值减 1

    LEA

    示例:LEA EAX,[ECX+4]  含义:EAX = ECX+4  解释:将 ECX+4 的值存入 EAX

    CMP

    示例:CMP EAX,ECX
    含义:

    if(EAX == ECX){ZF=1} else ZF=0

    解释:对两个值进行比较并根据结果设置标志,若 EAX 与 ECX 相同,则 ZF=1,若 EAX 与 ECX 不同,则 ZF=0

    TEST

    示例:TEST EAX

    含义:

    if(EAX == 0) ZF=1 else ZF=0

    解释:将值与 0 进行比较并根据结果设置标志,若 EAX 为 0,则 ZF=1,若 EAX 不为 0,则 ZF=0

    JE(JZ)

    示例:JE 04001000  含义:if(ZF==1)GOTO 04001000  解释:若 ZF 为 1,则跳转到 04001000

    JNE(JNZ)

    示例:JNE 04001000  含义:if(ZF==0) GOTO 04001000  解释:若 ZF 为 0,则跳转到 04001000

    JMP

    示例:JMP 04001000  含义:GOTO 04001000  解释:无条件跳转到 04001000

    CALL

    示例:CALL lstrcmpW  解释:调用 lstrcmpW

    PUSH

    示例:PUSH 00000001  解释:将 00000001入栈

    POP

    示例:POP EAX  解释:出栈并将获取的值存入EAX

    如果还有一些常用的,欢迎大家留言指出,我会继续补充。

    • 本文由 发表于 2018年10月8日14:27:07
    • 转载请务必保留本文链接:https://www.huojunqiang.com/29.html
    匿名

    发表评论

    匿名网友 填写信息

    :?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: