[汇编语言]-第九章 根据位移进行转移的jmp指令 段内短转移 段内近转移 段间转移(远转移) 转移的目的地址在指令中,在寄存器中,在内存中的jmp指令
1- jmp为无条件转移指令,可以只修改IP, 也可以同时修改CS和IP
jmp指令要给出两种信息:
(1) 转移的目的地址
(2) 转移的距离(段间转移, 段内转移, 段内近转移)
2- 依据位移进行转移的jmp指令
jmp short 标号(转到表号处执行指令) ;段内短转移 -128-127
assume cs:codesg
codesg segment
start: mov ax,
jmp short s
add ax,
s:inc ax
codesg ends
end start
执行后 ax 0001H
2- 根据位移进行转移的原理
assume cs:codesg
codesg segment
start: mov ax,
jmp short s
add ax,
s:inc ax
codesg ends
end start

图1
assume cs:codesg
codesg segment
start: mov ax,
jmp short s
add ax,
add ax,
s:inc ax
codesg ends
end start

图2
图1jmp 需要转移到 cs:0008 ,图2jmp需要转移到 cs:000B 两图的jmp 行代码的机器指令为 EB03 和 EB06 , 可见CPU在指令jmp命令的时候并不需要转移的目的地址.主要控制转移到哪里的是机器指令中得 EB,EB06. 03 和 06
首先回忆下CPU执行指令的过程:
(1) 从cs:ip指向的内存单元读取指令,读取的指令进入指令缓冲区.
(2) (IP) = (IP) + 所读取指令的长度, 从而指向下一条指令
(3) 执行指令. 转到1, 重复这个过程
按照以上步骤,(图1)查看程序执行jmp short s指令的执行过程:
(1) CS:0B60 IP:0003 CS:IP指向EB03(jmp short s 的机器码)
(2) 读取指令码EB03进入指令缓冲区
(3) (IP)=(IP)+所读取的指令长度=(IP)+2 = 0005, CS:IP指向 add ax,1
(4) CPU执行指令缓冲区的指令EB03
(5) 指令EB03执行后(IP)=0008H CS:IP指向 inc ax IP由原来的 0005 + 03(及EB03中得03) = 0008
实际上指令jmp short "标号" 段内短转移 的功能为: (IP) = (IP) + 8位位移
(1) 8位位移 = "标号"处的地址 - jmp指令后的第一个字节的地址
(2) short指明此处位移为8位位移
(3) 8位位移的范围-128-127,用补码表示
(4) 8位位移由编译程序在编译时算出
jmp near ptr 标号 实现段内近转移 功能为 (IP) = (IP) + 16位位移
(1) 16位位移 = "标号"处的地址 - jmp指令后的第一个字节的地址
(2) near prt 指明此处位移为16位位移,进行的是段内近转移
(3) 16位位移的范围-32768-32767,用补码表示
(4) 16位位移由编译程序在编译时算出
3- 转移的目的地址在指令中的jmp指令
jmp far ptr 标号 实现的是,段间转移,又称为远转移.指明了指令用标号的段地址和偏移地址.
assume cs:codesg
codesg segment
start: mov ax,
mov bx,
jmp far ptr s
db dup ()
s: add ax,
inc ax mov ax,4c00H
int 21h
codesg ends
end start

CS:0B60 IP:010A 机器指令:EA0A01600B
4- 转移的目的地址在寄存器中的jmp指令
jmp 16位寄存器
(IP) = (16位寄存器)
5- 转移的目的地址在内存中的jmp指令
(1) jmp word ptr 内存单元地址(段内转移)
功能:从内存单元地址开始存放着一个字,是转移的目的偏移地址
mov ax,0123H
mov ds:[0],ax
jmp word ptr ds:[0]
执行后(IP) = 0123H
mov ax,0123H
mov [bx],ax
jmp word ptr [bx]
执行后(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
mov ax,0123H
mov [bx],ax
mov word ptr [bx+2],0
jmp dword ptr [bx]
执行后:(CS)=0 (IP)=0123H CS:IP指向0000:0123
assume cs:codesg
codesg segment
start: mov ax,2000H
mov ds,ax
mov bx,1000h
mov word ptr [bx].,0BEH
mov word ptr [bx].,6H
mov word ptr [bx]., mov ax,2000H
mov es,ax
jmp dword ptr es:[1000H]
codesg ends
end start
执行后:(CS)=0006 (IP)=00BEH CS:IP指向0006:00BE
[汇编语言]-第九章 根据位移进行转移的jmp指令 段内短转移 段内近转移 段间转移(远转移) 转移的目的地址在指令中,在寄存器中,在内存中的jmp指令的更多相关文章
- @清晰掉 C++ 中的 enum 结构在内存中是怎么存储的?
C++ 中的 enum 结构在内存中是怎么存储的? C++ C++ 中的 enum 结构在内存中是怎么存储的?里面存储的是常量值吗? 关于占用内存的大小,enum类型本身是不占内存的,编译器直接 ...
- vs中调试程序查看变量在内存中的内容的方法
vs中调试程序 查看变量在内存中的内容的方法 https://blog.csdn.net/guojg1988/article/details/42922149 原文链接:http://www.sows ...
- Tomcat启动时加载数据到缓存---web.xml中listener加载顺序(例如顺序:1、初始化spring容器,2、初始化线程池,3、加载业务代码,将数据库中数据加载到内存中)
最近公司要做功能迁移,原来的后台使用的Netty,现在要迁移到在uap上,也就是说所有后台的代码不能通过netty写的加载顺序加载了. 问题就来了,怎样让迁移到tomcat的代码按照原来的加载顺序进行 ...
- [汇编语言]-第九章 jcxz,loop指令,转移位移的意义
1- jcxz指令 指令为有条件转移指令, 所有的有条件转移指令都是短转移, 在对应的机器码中包含转移的位移, 而不是目的地址, 对IP的修改范围为: -128 ~ 127 指令格式: jcxz 标号 ...
- C/C++中整数与浮点数在内存中的表示方式
在C/C++中数字类型主要有整数与浮点数两种类型,在32位机器中整型占4字节,浮点数分为float,double两种类型,其中float占4字节,而double占8字节.下面来说明它们在内存中的具体表 ...
- java中的各种数据类型在内存中存储的方式
原文地址:http://blog.csdn.net/aaa1117a8w5s6d/article/details/8251456 1.Java是如何管理内存的 java的内存管理就是对象的分配和释放问 ...
- [汇编语言]-第九章 在屏幕中间分别显示绿底红色,白底蓝色字符串"welcome to masm!"
;在屏幕中间分别显示绿色,绿底红色,白底蓝色字符串"welcome to masm!" assume cs:codesg,ds:datasg,ss:stacksg datasg s ...
- JVM中java实例对象在内存中的布局
普通的Java对象实例 和 Java数组实例.Java数组实例的对象头多了一个数组的长度.Java虚拟机可以通过普通java对象的元数据来确定java对象的大小,但是从数组的元数据中却无法确定数组的 ...
- 内存中 OLTP - 常见的工作负荷模式和迁移注意事项(一)
----------------------------我是分割线------------------------------- 本文翻译自微软白皮书<In-Memory OLTP – Comm ...
随机推荐
- debian安装缺少网卡驱动rtl_nic/rtl8168e-2.fw和bcm43xx-0.fw
最近拿了公司一台旧笔记本来装debian玩,刻好盘之后安装,发现网卡驱动都无法装上. 这是因为这些网卡驱动不是开源的,顽固的debian便将他们从驱动列表中移除了... 我从debian官方找到了这两 ...
- QObject的event函数就可以改写对消息的处理
一个既自己处理Tab事件又自己处理某些按键事件,然后将其它不需自己处理的事件转发给基类处理: bool MyWidget::event(QEvent *event){ if (event->ty ...
- 配置文件入门 - WebConfig.config常用配置节点介绍
一.配置文件入门 .Net提供了一种保存项目配置信息的办法,就是利用配置文件,配置文件的后缀一般是.config.在WinForm程序中配置文件一般是App.config.在Asp.net中一般默认是 ...
- WPF笔记(1.4 布局)——Hello,WPF!
原文:WPF笔记(1.4 布局)--Hello,WPF! 这一节只是第2章的引子.布局要使用Panel控件,有四种Panel,如下:DockPanel,就是设置停靠位置布局模型.StackPanel, ...
- Linux系统编程(1)——文件与I/O之C标准I/O函数与系统调用I/O
Linux系统的I/O也就是一般所说的低级I/O--操作系统提供的基本IO服务,与os绑定,特定于Linux平台.而标准I/O是ANSI C建立的一个标准I/O模型,是一个标准函数包和stdio.h头 ...
- spring-boot+nginx+tomcat+ssl配置笔记
如果你的tomcat应用需要采用ssl来加强安全性,一种做法是把tomcat配置为支持ssl,另一种做法是用nginx反向代理tomcat,然后把nginx配置为https访问,并且nginx与tom ...
- 【转】C/C++程序员应聘常见面试题深入剖析
1.引言 本文的写作目的并不在于提供C/C++程序员求职面试指导,而旨在从技术上分析面试题的内涵.文中的大多数面试题来自各大论坛,部分试题解答也参考了网友的意见. 许多面试题看似简单,却需要深厚的基 ...
- PHP 9 大缓存技术总结
1.全页面静态化缓存 也就是将页面全部生成html静态页面,用户访问时直接访问的静态页面,而不会去走php服务器解析的流程.此种方式,在CMS系统中比较常见,比如dedecms: 一种比较常用的实现方 ...
- django 启动和请求
Django运行方式 调试模式 直接 python manage.py runserver python manage.py runserver python manage.py runserver ...
- 使用ASIHttoRequest需要导入的framework
需要导入如下framework libxml2.2.dylib libz.1.2.5.dylib MobileCoreServices.framework SystemConfiguration.fr ...