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

相关推荐
7***u2169 分钟前
显卡(Graphics Processing Unit,GPU)架构详细解读
大数据·网络·架构
whale fall1 小时前
【剑雅14】笔记
笔记
红树林072 小时前
渗透测试之sql注入--报错注入
数据库·sql·安全·web安全
星空的资源小屋2 小时前
跨平台下载神器ArrowDL,一网打尽所有资源
javascript·笔记·django
Xudde.3 小时前
Quick2靶机渗透
笔记·学习·安全·web安全·php
河北瑾航科技3 小时前
广西水资源遥测终端 广西水利遥测终端 广西用水监测遥测终端 河北瑾航科技遥测终端机HBJH-B01说明书
网络·科技·水文遥测终端机·遥测终端机·广西水资源遥测终端机·广西水利遥测终端·广西用水终端
岁岁的O泡奶3 小时前
DVWA_Vulnerability: Command Injection
经验分享·安全·web安全
AA陈超3 小时前
Git常用命令大全及使用指南
笔记·git·学习
羑悻的小杀马特4 小时前
轻量跨云·掌控无界:Portainer CE + cpolar 让远程容器运维像点外卖一样简单——免复杂配置,安全直达对应集群
运维·网络·安全·docker·cpolar
愚戏师4 小时前
Python3 Socket 网络编程复习笔记
网络·笔记