8086汇编中jmp指令详解..docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
8086汇编中jmp指令详解.

8086汇编中jmp jmp指令 解释: ??????? jmp为无条件转移,可以只修改IP,也可以同时修改CS和IP; ??????? jmp指令要给出两种信息: ??????? 转移的目的地址 ??????? 转移的距离(段间转移、段内短转移,段内近转移) 格式: 一.Jump short 这种格式的 jmp 指令实现的是段内短转移,它对IP的修改范围为 -128~127,也就是说,它向前转移时可以最多越过128个字节,向后转移可以最多越过127个字节。 示例: assume cs:codesg codesg segment start:mov ax,0 jmp short s add ax,1 s:inc ax codesg ends end start 说明:上面的程序执行后, ax中的值为 1 ,因为执行 jmp short s 后 ,越过了add ax,1 ,IP 指向了标号 s处的 inc ax。也就是说,程序只进行了一次ax加1操作。 注意: ??????? 汇编指令jmp short s 对应的机器指令应该是什么样的呢? ??????? 我们先看一下别的汇编指令和其对应的机器指令 可以看到,在一般的汇编指令中,汇编指令中的idata(立即数),不论它是表示一个数据还是内存单元的偏移地址,都会在对应的机器指令中出现,因为CPU执行的是机器指令,它必须要处理这些数据或地址。 ??????? 但是:当我们查看jmp short s或jmp 0008所对应的机器码,却发现了问题。 看到了吗?机器码中并不含有立即数。为什么呢,解释如下 ??????? 在“jmp short 标号”指令所对应的机器码中,并不包含转移的目的地址,而包含的是转移的位移。 ??????? 这个位移,使编译器根据汇编指令中的“标号”计算出来的。 如果我们在第一行程序后加上Mov bx,0000,你会发器机器码没变,还是EB03,为什么呢?jmp 0008对应的偏移就是0003大家可以回忆一下cpu中指令的执行流程,就会发现当执行完EB03后,ip=ip+2=0005,大家注意看EB03后面有个03,表示再向后三个单位,这样就到了0008这个偏移处了。所以我们说包含 的是转移的位移。 转移位移具体的计算方法如下图 二.还有一种和指令“jmp short 标号”功能相近的指令格式: jump near ptr 标号 实现的时段内近转移。 指令“jmp near ptr 标号”的功能为:(IP)=(IP)+16位位移。 ??????????? 指令“jmp near ptr 标号”的说明: ????????????????? (1)16位位移=“标号”处的地址-jmp指令后的第一个字节的地址; ????????????????? (2)near ptr指明此处的位移为16位位移,进行的是段内近转移; ????????????????? (3)16位位移的范围为 -32769~32767,用补码表示; ????????????????? (4)16位位移由编译程序在编译时算出。 我们发现jump short 标号与jump near ptr 标号非常相似,不同点在哪儿呢?实际上就是跳转的范围,看下面一段代码: assume cs:codesg codesg segment start:mov ax,0 jmp near ptr s add ax,1 dw 200 dup(2)此处表示生成若干条汇编指令,从而产生多个地址,方便测试 s:inc ax codesg ends end start 如果我们将此处的jmp near ptr s 改为jmp short s,那么编译时会报这样的错误 jump out of range by 276 bytes,即jump越界了。也就是说: 在编译的时候由编译程序算出是8位还是16位位移。8位位移的范围是2的7次方,而16位位移的范围是2的15次方。 三.回顾前面讲的jmp指令,其对应的机器码中并没有转移的目的地址,而是相对于当前IP的转移位移。 指令 “jmp far ptr 标号” 实现的是段间转移,又称为远转移 ??????? 指令 “jmp far ptr 标号” 功能如下: ??????? (CS)=标号所在段的段地址; ??????? (IP)=标号所在段中的偏移地址。 ??????? far ptr指明了指令用标号的段地址和偏移地址修改CS和IP。 实例: assume

文档评论(0)

kaiss + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档