Conanholmes 发表于 2017-11-12 16:11:49

jmp指令究竟是占几个字节

本帖最后由 Conanholmes 于 2017-11-12 16:17 编辑

昨晚在弄零号中断程序也就是除法溢出那个发现了个问题,所以来请教大家
就是jmp指令究竟是占几个字节


第一张图   jmp+标号指令后有126个inc ax   ,第二张图 jmp+标号指令后有127个inc ax.
我编了个小程序debug了一下,(上图)
jmp+标号指令后当所跳转的长度少于127时,debug里显示jmp+标号指令后有个 nop,然后再到inc ax,jmp+标号指令相应的就占了两个字节,但当所跳转的长度等于或大于127时,debug里显示 jmp+标号指令后的nop不见了,jmp+标号指令相应的就占了3个字节,到这里,我有点不是很懂“jmp+标号”这个指令是占两个字节还是三个字节。   

请各位大神帮忙解释下,谢谢。

无符号整形 发表于 2017-11-12 18:21:30

要善于使用搜索功能哦:http://bbs.fishc.com/thread-27535-1-1.html
前辈已经问过了哦~{:10_257:}

兰陵月 发表于 2017-11-13 10:19:55

本帖最后由 兰陵月 于 2017-11-13 10:23 编辑

来自李忠《X86汇编语言—从实模式到保护模式》第138页



如果是相对短转移,那“JMP+标号”就是两字节长度。

如果是相对近转移,那“JMP+标号”就是三字节长度。

Conanholmes 发表于 2017-11-13 19:25:27

无符号整形 发表于 2017-11-12 18:21
要善于使用搜索功能哦:http://bbs.fishc.com/thread-27535-1-1.html
前辈已经问过了哦~

明白了,谢谢
页: [1]
查看完整版本: jmp指令究竟是占几个字节