汇编语言:loop指令

loop指令是循环指令,在8086CPU中,所有的循环指令都是短转移,其对应的机器指令有2个字节,低8位字节存放的是操作码;高8位字节存放的是转移位移(相对于当前IP的位移),用补码形式表示,范围在:-128 ~ 127。

指令格式:loop 标号

loop 标号 指令的循环次数存放在cx寄存器中,其基本原理为:

  1. (cx) = (cx) -1;

  2. (1)如果 (cx) != 0,则 (IP) = (IP) + 8位位移,控制CPU回到标号处执行指令。

(2)如果 (cx) = 0,什么都不做,程序继续往下顺序执行指令。

其功能就像 C 语言所描述的代码:if ((cx) != 0 ) jmp short 标号;

示例:利用 loop 指令,实现从CS(段地址)中查找第一个值为0的字节,并把偏移地址存储在dx寄存器中

cpp 复制代码
assume cs:code
code segment
start:
    mov ax, cs
    mov ds, ax
    mov bx, 0
s:
    mov cl, [bx]    ;cl = ds:[bx]指向的一个字节数据
    mov ch, 0       ;cx的高8位置0
    inc cx          ;因为执行 loop s 指令, cx = cx - 1, 所以这里要 inc cx
    inc bx          ;让偏移地址移向下一个字节单元
    loop s          ;(1)cx = cx -1; 
                    ;(2) --如果 cx != 0, IP = IP + 8位位移,CPU回到S标号指向的指令处执行指令
                    ;    --如果 cx == 0,什么都不做,CPU继续顺序往下执行指令
    dec bx          ;
    mov dx, bx
    mov ax, 4c00h
    int 21h

code ends
end start

从图中,我们可知,程序加载到内存后

(1)-r 查看各个寄存器设置情况,CS:IP = 204D:0000

(2)-d cs:0 查看128个字节的内存中,偏移地址 = 5,是第一个值为 0 的字节

(3)-u 查看汇编指令以及其对应的机器码

(4)-g 0012 控制CPU从CS:IP指向的指令处开始执行指令,直到 IP = 0012 时停下来,这时 dx = 0005,和我们在步骤(2)中观察到的第一个值为 0 的字节的偏移地址 = 5 是一致的

(5)loop s 被编译器编译成 loop 0007,其对应的机器指令为:E2F8(低字节序),低8位:E2是操作码,高8位:F8是转移位移,转移位移 = 0007h - 000Fh = -8(十进制) = F8h(负数的补码形式)。

参考文献

《汇编语言(第4版)》王爽

相关推荐
谁动了我的代码?6 分钟前
VNC中使用QT的GDB调试,触发断点时与界面窗口交互导致整个VNC冻结
开发语言·qt·svn
We་ct15 分钟前
LeetCode 212. 单词搜索 II:Trie+DFS 高效解法
开发语言·算法·leetcode·typescript·深度优先·图搜索算法·图搜索
OxyTheCrack20 分钟前
【C++】简述main函数中的argc与argv
开发语言·c++
历程里程碑27 分钟前
Linux 49 HTTP请求与响应实战解析 带http模拟实现源码--万字长文解析
java·开发语言·网络·c++·网络协议·http·排序算法
ZVAyIVqt0UFji28 分钟前
高可用虚拟IP(HaVip)技术详解:原理、设计与应用
开发语言·网络·网络协议·tcp/ip·perl
飞Link29 分钟前
深度解析 TS2Vec:时序表示学习中的层次化建模(Hierarchical Contrastive Learning)
开发语言·python·学习·数据挖掘
爱炸薯条的小朋友31 分钟前
C#依赖注入和仿写Prism注入
开发语言·c#
代码探秘者32 分钟前
【Java集合】ArrayList :底层原理、数组互转与扩容计算
java·开发语言·jvm·数据库·后端·python·算法
OxyTheCrack39 分钟前
简述各语言GC(垃圾回收)机制
开发语言
李昊哲小课40 分钟前
电商系统项目教程
开发语言·前端·javascript