8086 汇编笔记(八):转移指令的原理

一、操作符 offset

操作符offset在汇编语言中是由编译器处理的符号,它的功能是取得标号的偏移地址

codesg segment

start:  mov ax,offset start    ;相当于 mv ax,0
  s:    mov ax,offset s        ;相当于 mv ax,3

codesg ends

end start

二、jmp 指令

jmp为无条件转移指令,可以只修改IP,也可以同时修改CS和IP

jmp指令要给出两种信息:

(1)转移的目的地址

(2)转移的距离(段间转移、段内短转移、段内近转移)

三、依据位移进行转移的 jmp 指令

主要用于在同一代码段内进行较短距离的跳转(不超过127字节)

jmp short 标号    ;(IP) = (IP) + 8 位位移

codesg segment

start:  mov ax,0
        jmp short s
        add ax,1
  s:    inc ax

codesg ends

end start

直接跳转到了 s 处,略过了 add ax,1

16 位位移的范围为 -32768~32767

jmp near ptr 标号    ;(IP) = (IP) + 16 位位移

四、转移的目的地址在指令中的 jmp 指令

jmp far ptr 标号

实现的是段间转移,又称为远转移。功能如下:

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

far ptr 指明了指令用标号的段地址和偏移地址修改CS和IP。

五、转移地址在寄存器中的 jmp 指令

jmp 16 位的 reg

功能:(IP) = (16 位 reg)

六、转移地址在内存中的 jmp 指令

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

jmp dword ptr 内存单元地址(段间转移)

功能:从内存单元地址处开始存放着两个字,高地址处的字是转移的目的段地址,低地址处是转移的目的的偏移地址

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

七、jcxz 指令

jcxz 标号

功能:如果(cx)=0,则转移到标号处执行。如果(cx)≠ 0,则程序继续向下执行

八、loop 指令

loop 标号

功能:(cx)=(cx)-1,如果(cx)≠ 0,则转移到标号处执行

相关推荐
啥都想学的又啥都不会的研究生1 分钟前
Redis设计与实现-服务器中的数据库
运维·服务器·数据库·redis·笔记·缓存·性能优化
.昕..7 分钟前
(二)seacmsv9注入管理员账号密码+orderby+limit
python·网络安全
学习嵌入式的小羊~17 分钟前
视频图像刷新到HTTP的原理
网络·网络协议·http
瞬 季29 分钟前
计算机网络-应用层
网络·计算机网络
Enjoy_zhuo40 分钟前
文件上传漏洞(条件竞争)
安全·web安全
薛定谔的码*1 小时前
计算机三级网络技术备考(5)
网络·智能路由器
网络设计ensp2 小时前
企业网设计
网络·智能路由器
鸭梨山大。2 小时前
linux命令-iptables与firewalld 命令详解
linux·运维·网络
瑶光守护者2 小时前
并行计算编程模型的发展方向与RISC-V的机遇
人工智能·笔记·学习·架构·risc-v
半夏知半秋2 小时前
linux下的网络抓包(tcpdump)介绍
linux·运维·服务器·网络·笔记·学习·tcpdump