汇编Jmp指令总结
来源:互联网 发布:如何下载软件 编辑:程序博客网 时间:2024/05/16 18:54
一.转移的目的地址在指令中的jmp指令
1.jmp short 标号
功能:IP=IP+8位位移
2.jmp near ptr 标号
功能:IP=IP+16位位移
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 near ptr 标号
jcxz 标号
loop 标号
等几种汇编指令,它们对IP的修改是根据转移目的地址和转移起始地址之间的位移来进行的。在它们对应的机器码中不包含转移的目的地址,而包含的是到目的地址的位移。
- 汇编Jmp指令总结
- 汇编学习--jmp指令
- 汇编jmp指令
- 汇编jmp指令用法
- 汇编 jmp指令
- 汇编指令jmp的理解
- 汇编转移指令jmp原理
- jmp指令用法总结
- 汇编指令jmp call ret 变形
- 汇编指令CALL与JMP的区别
- jmp指令
- JMP指令
- jmp指令
- jmp 指令
- jmp指令
- JMP指令
- 汇编----正确区分LJMP、AJMP、SJMP、JMP跳转指令
- 一步步学习汇编(10)之jmp指令原理分析
- POJ1270【拓扑排序+DFS】
- Mysql学习——MySQL导入导出.sql文件及常用命令
- Jacob操作office文档(Word,PPT,Excel)
- 表值函数
- Win8下 OPENCV3.1 配置CUDA7.5+opencv_contrib
- 汇编Jmp指令总结
- Mysql各种类型字段长度
- leetcode 198. House Robber
- QNX Bootloader 启动顺序
- 银联支付-SDK使用、测试流程
- Start application automatically during controller boot-up
- lua中字符串匹配笔记
- XTU 1233 Coins(DP)
- Master-Detail Application的纯代码实现