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+标号”这个指令是占两个字节还是三个字节。
请各位大神帮忙解释下,谢谢。 要善于使用搜索功能哦:http://bbs.fishc.com/thread-27535-1-1.html
前辈已经问过了哦~{:10_257:} 本帖最后由 兰陵月 于 2017-11-13 10:23 编辑
来自李忠《X86汇编语言—从实模式到保护模式》第138页
如果是相对短转移,那“JMP+标号”就是两字节长度。
如果是相对近转移,那“JMP+标号”就是三字节长度。 无符号整形 发表于 2017-11-12 18:21
要善于使用搜索功能哦:http://bbs.fishc.com/thread-27535-1-1.html
前辈已经问过了哦~
明白了,谢谢
页:
[1]