关闭

汇编Jmp指令总结

181人阅读 评论(0) 收藏 举报

一.转移的目的地址在指令中的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的修改是根据转移目的地址和转移起始地址之间的位移来进行的。在它们对应的机器码中不包含转移的目的地址,而包含的是到目的地址的位移。
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:19420次
    • 积分:561
    • 等级:
    • 排名:千里之外
    • 原创:38篇
    • 转载:6篇
    • 译文:0篇
    • 评论:1条
    最新评论