JS、JNS、JP(JPE)、JNP(JPO)指令详解、从原理上解释

  • JS
    格式:
js 地址

当执行到JS指令时,如果标志位SF=1,则跳转到指定的地址,如果SF=0,不跳转

比如:

cmp eax,ecx
js 0040100c

此时eax=0,ecx=1,执行完cmp命令,符号标志位SF=1,执行到JS时,跳转到0040100c处执行

  • JNS
    格式:
jns 地址

当执行到JNS指令时,如果标志位SF=0,则跳转到指定的地址,如果SF=1,不跳转,和JS刚好相反

  • JP、JPE
    JP和JPE是一个意思,只不过是写法不同,当执行到JPE(JP)命令时,如果此时标志位PF=1,则跳转到指定的地址,如果PF=0,不跳转
cmp eax,ecx
jpe 0040100c

此时eax=0x20,ecx=0x17,执行完cmp,结果为0x3,转换为二进制为11,1的个数为偶数个,所以PF=1,跳转到0040100c处执行

  • JNP、JPO
    JNP、JPO也是一个意思,不同写法而已,当执行到JNP(JPO)命令时,如果此时标志位PF=0,则跳转到指定的地址,如果PF=1,不跳转
cmp eax,ecx
jpe 0040100c

此时eax=0x20,ecx=0x18,执行完cmp,结果为0x32,转换为二进制为01,1的个数为奇数个,所以PF=0,跳转到0040100c处执行

发布了203 篇原创文章 · 获赞 19 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/qq_41683305/article/details/105547177