<学习笔记>王爽汇编语言__转移指令原理
来源:互联网 发布:淘宝淘字图片 编辑:程序博客网 时间:2024/04/27 23:57
可以修改IP,或者可以同时修改CS和IP的指令统称为转移指令。
8086CPU的转移行为有以下几类:
* 只修改IP时,称为段内转移,比如:jmp ax
* 同时修改CS和IP时,称为段间转移,比如:jmp 1000:0
由于转移指令对IP的修改范围不同,段内转移又分为:短转移和近转移
* 短转移IP的修改范围为:-128~127
* 近转移IP的修改范围为:-32768~32767
8086CPU的转移指令分为以下几类
* 无条件转移
* 条件转移
* 循环指令
* 过程
* 中断
1.操作符:offset
操作符offset在汇编语言中是由编译器处理的符号,它的功能是取得标号的便宜地址,例如:
assume cs:codesgcodesg segment start: mov ax,offset start s: mov ax,offset scodesg endsend start
2.jmp指令
jmp为无条件转移指令,可以只修改IP,也可以同时修改CS和IP
3.依据位移进行转移的jmp指令
jmp short标号(转到标号处执行指令)
这种格式的jmp指令实现的是段内短转移,他对IP的修改范围为:-128~127。
比如以下程序:
assume cs:codesgcodesg segmentstart: mov ax , 0 jmp short s add ax , 1codesg endsend start
上面程序执行后,ax中的值为1,跳过了add ax , 1这条指令。
jmp short s这条指令被Debug翻译成:jmp 0008,这个0008并不是目的地址,而是转移的地址长度。
4.转移目的的地址在指令中的jmp指令
jmp far ptr 实现的是段间的转移,又称为远转移,例如程序:
assume cs:codesgcodesg segment start: mov ax , 0 mov bx , 0 jmp far ptr s db 256 dup (0) s: add ax , 1 inc axcodesg endsend start这段代码中的 jmp far ptr s 被Debug翻译成 :jmp 0BBD:0000
5.转移地址在寄存器中的jmp指令
指令格式:jmp 16位reg
6.转移地址在内存中的jmp指令
功能:从内存单元地址出开始存放着第一个字,是转移的目的的偏移地址。
有两种格式:
(1)jmp word ptr 内存单元地址(段内转移)
比如如下指令:
mov ax , 0123Hmov ds:[0] , axjmp word ptr ds:[0]执行后:(IP)=0123H
(2)jmp dword ptr
功能:从内存单元地址处开始存放着两个字,高地址处的字是转移的目的段地址,低地址处是转移的目的偏移地址。
比如下面指令:
mov ax , 0123Hmov ds:[0] , axmov word ptr ds:[2] , 0jmp dword ptr ds:[0]
执行后CS = 0 ,IP = 0123H
7.jcxz指令
jcxz指令为条件转移指令,所有的条件转移指令都是短转移。
指令格式:jcxz标号(如果(cx) = 0,转移到标号处执行)
8.loop指令
loop指令为循环指令,所有的循环指令都是短转移。
指令格式:loop 标号((cx) = (cx) - 1,如果(cx) != 0 , 转移到标号处执行)
- <学习笔记>王爽汇编语言__转移指令原理
- 王爽汇编语言学习笔记(九) --转移指令的原理
- <学习笔记>王爽汇编语言__[BX]和loop指令
- 汇编语言学习笔记(九)转移指令的原理
- <学习笔记>王爽汇编语言__寄存器
- 汇编语言-转移指令的原理
- 王爽《汇编语言》(第二版) 学习笔记 (第九章 转移指令的原理 )
- 王爽《汇编语言》(第二版) 学习笔记 (第九章 转移指令的原理 )
- 汇编语言学习第九章-转移指令的原理
- 汇编学习笔记--转移指令的原理
- <学习笔记>王爽汇编语言__再论寄存器
- <学习笔记>王爽汇编语言__包含多个段的程序
- <学习笔记>王爽汇编语言__标志寄存器
- 汇编语言之转移指令和原理
- 读王爽老师汇编语言笔记---转移指令的原理和call,ret指令
- 《汇编语言》学习(九)转移指令
- 汇编学习笔记----转移指令及子程序原理
- [汇编学习笔记][第九章转移指令的原理]
- VIM 的色彩配置相关的问题
- More Effective C++总结(3):异常
- shell文件操作【转】
- MyEclipse 优化的基本优化
- 动态树的管理程序(基于jQuery Treeview实现)
- <学习笔记>王爽汇编语言__转移指令原理
- 关于Java的传值和传址问题
- 今年全力攻克英语!!!
- JVM中的Stack和Heap
- iPhone iPad iOS 开发环境 之 XCODE 4.1 on Lion
- memcached 重启
- 客服服务、广告随滚动条滚动(通用)
- Matlab中如何添加工具箱
- HTML5 Game Development Tutorial