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 小时前
HCM智能人力资源系统存在命令执行漏洞Getshell
网络·计算机网络·安全·web安全·网络安全·系统安全·安全架构
十年一梦实验室6 小时前
【C++】相机标定源码笔记- 标定工具库测试
笔记·数码相机
helloKittywz6 小时前
内网学习第6天 liunx定时任务 环境变量和权限配置,以及数据库提权
学习·web安全·网络安全·内网渗透·liunx·权限提升·学习记录
炫酷的伊莉娜7 小时前
【网络安全】第3讲 消息认证技术(笔记)
笔记·安全·web安全
Lyx-06077 小时前
项目进度管理(信息系统项目管理师)
笔记
爱学习的南瓜7 小时前
笔记14:程序中的循环结构
c语言·笔记
LNTON羚通7 小时前
视频共享融合赋能平台LnyonCVS国标视频监控平台包含哪些功能
大数据·网络·人工智能·算法·音视频
Java追光着7 小时前
谷粒商城笔记-02-项目整体效果展示
笔记
开开心心kai7 小时前
不花钱如何让网站启用HTTPS访问
网络·网络协议·安全·http·https
平安喜乐6167 小时前
探索 SecureCRT:强大的终端 SSH 工具
网络·securecrt·终端 ssh 工具