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,则转移到标号处执行

相关推荐
叫我龙翔几秒前
【计网】实现reactor反应堆模型 --- 多线程方案优化 ,OTOL方案
linux·运维·网络
网络安全工程师老王1 分钟前
web3+web2安全/前端/钱包/合约测试思路——尝试前端绕过直接上链寻找漏洞
安全·web安全·网络安全·信息安全·web3
?crying42 分钟前
蓝队基础4 -- 安全运营与监控
网络·安全·web安全
茶颜悦色vv1 小时前
蓝队知识浅谈(中)
网络·web安全·网络安全
Xlbb.1 小时前
安全见闻6-9
网络·安全·web安全·网络安全
杜若南星2 小时前
保研考研机试攻略(满分篇):第二章——满分之路上(1)
数据结构·c++·经验分享·笔记·考研·算法·贪心算法
写bug的小屁孩2 小时前
websocket初始化
服务器·开发语言·网络·c++·websocket·网络协议·qt creator
域智盾系统2 小时前
挖到宝了!统一dlp数据防泄漏解决方案有哪些?千字长文带你熟知这6款!
网络·数据防泄漏·统一dlp数据防泄漏解决方案·数据安全防护措施
茶颜悦色vv2 小时前
蓝队知识浅谈(上)
网络·web安全·网络安全
石牌桥网管2 小时前
DNS Resolver解析服务器出口IP查询
运维·网络·tcp/ip·dns