您的位置:首页 > 其它

汇编Jmp指令总结

2016-06-01 15:10 211 查看
一.转移的目的地址在指令中的jmp指令

1.jmp short 标号       --实现段内转移


功能:IP=IP+8位位移  (位移范围在-128~127,用补码表示。)

2.jmp near ptr 标号    --实现段内转移

功能:IP=IP+16位位移  (位移范围在-32768~32767,用补码表示。)

3.jmp far ptr 标号     --实现段间转移

(CS)=标号所在段的段地址;(IP)=标号在段中的偏移地址。

分析 上面三个指令的区别:

1>jmp short ptr 标号指令<=jmp near ptr 标号 指令<=jmp far prt 标号 指令
2>当转移范围在-128~127时,jmp near prt 标号指令也可以使用,此时在功能上,

jmp short ptr 标号 指令=jmp near ptr 标号 指令
3>设转移范围为X,当-32768<X<-128或127<X<32767时,不能使用jmp short ptr 标号 指令,应该使用

jmp near ptr 标号 指令。

4>当标号和jmp far ptr 标号指令在同一段时,也可以使用jmp far ptr 标号 指令,此时在功能上

jmp near ptr 标号 指令=jmp far prt 标号 指令
5>而当标号和jmp far ptr 标号指令不在同一段时,不能使用jmp near ptr 标号 指令,应该使用

jmp far ptr 标号 指令。

 

二.转移地址在寄存器中的jmp指令

指令格式:jmp 16位寄存器


功能:(IP)=(16位寄存器)
注意:是16位寄存器!8位寄存器不能够,因为IP是16位的,不能与8位寄存器进行操作。

 

三.转移地址在内存中的jmp指令

1.jmp word ptr 内存单元地址(段内转移)

例如,下面的指令:

mov ax,0123H

mov ds:[0],ax

jmp word ptr ds:[0]

执行后,(IP)=0123H

2.jmp dword ptr 内存单元地址(段间转移)
功能:从内存单元地址处开始存放着两个字,高地址处的字是转移的目的段地址,低地址处是转移的目的偏移地址。

(CS)=(内存单元地址+2)

(IP)=(内存单元地址)

例如,下面的指令:

mov ax,0123H

mov ds:[0],ax

mov word ptr ds:[2],0

jmp dword ptr ds:[0]

执行后,(CS)=0,(IP)=0123H,CS:IP指向0000:0123。

3.jcxz指令:有条件转移指令,所有的有条件转移指令都是短转移,在对应的机器码中包含转移的位移,而不是目的地址。对IP的修改范围都为:-128~127.

指令格式:jcxz 标号(如果(CX)=0,转移到标号处执行.)

用C++和汇编混合表示就是:if((cx)==0)jmp short 标号


4.loop指令:为循环指令,所有的循环指令都是短转移,在对应的机器码中包含转移的位移,而不是目的地址。对IP的修改范围都为:-128~127.

指令格式:loop 标号((cx)=(cx)-1,如果(cx)!=0,转移到标号处执行。)

用C++和汇编混合表示就是:if((cx)<>0)jmp short 标号

注意:


jmp short 标号

jmp near ptr 标号

jcxz 标号

loop 标号

等几种汇编指令,它们对IP的修改是根据转移目的地址和转移起始地址之间的位移来进行的。在它们对应的机器码中不包含转移的目的地址,而包含的是到目的地址的位移。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: