8086 汇编笔记(四):[BX] 和 loop 指令

一、[BX]

bx\] 同样也表示一个内存单元,它的偏移地址在 bx 中,比如下面的指令: mov ax,[bx] ## 二、loop 指令 通常我们用 loop 指令来实现循环功能,cx 中存放循环次数 案例:计算 2\^12 codesg segment mov ax,2 mov cx,11 s: add ax,ax loop s mov ax,4C00H int 21H codesg ends end CPU 执行 loops 的时候,要进行两步操作: 1:(cx)(cx)-1; 2:判断 cx 中的值,不为0则转至标号s所标识的地址处执行(这里的指令是 add ax,ax),如果为0则执行下一条指令(下一条指令是 mov ax,4c00h)。 ## 三、Debug 和汇编编译器 masm 对指令的不同处理 (1) 在汇编源程序中,如果用指令访问一个内存单元,则在指令中必须用"\[...\]"来表示内存单元,如果在"门"里用一个常量 idata 直接给出内存单元的偏移地址,就要在"\[\]"的前面显式地给出段地址所在的段寄存器。比如 mov al,ds:[0] 如果没有在 "\[\]" 的前面显式地给出段地址所在的段寄存器,比如 mov al,[0] 那么,编译器 masm 将把指令中的"\[idata\]"解释为"idata" (2) 如果在"门"里用寄存器,比如 bx,间接给出内存单元的偏移地址,则段地址默认在 ds 中。当然,也可以显式地给出段地址所在的段寄存器。 ## 四、段前缀 mov ax,cs:[0] mov ax,ss:[0] mov ax,es:[bx] mov ax,ss:[bx] mov ax,ds:[bx] 这些出现在访问内存单元的指令中,用于显式地指明内存单元的段地址的 "ds:","cs:","ss","es"在汇编语言中称为**段前缀** ## 五、一段安全的空间 1. 我们需要直接向一段内存中写入内容; 2. 这段内存空间不应存放系统或其他程序的数据或代码,否则写入操作很可能引发错误; 3. DOS 方式下,一般情况,0:200\~0:2ff 空间中没有系统或其他程序的数据或代码; 4. 以后,我们需要直接向一段内存中写入内容时,就使用 0:200\~0:2ff这段空间。

相关推荐
迷藏494几秒前
**eBPF实战进阶:从零构建网络流量监控与过滤系统**在现代云原生架构中,**网络可观测性**和**安全隔离**已成为
java·网络·python·云原生·架构
zmj32032413 分钟前
汽车电子内部网络架构图
网络·汽车
一袋米扛几楼9824 分钟前
【网络安全】Splunk 是什么?
安全·web安全
一袋米扛几楼9829 分钟前
【网络安全】SIEM -Security Information and Event Management 工具是什么?
前端·安全·web安全
AI_Claude_code37 分钟前
ZLibrary访问困境方案三:Web代理与轻量级转发服务的搭建与优化
爬虫·python·web安全·搜索引擎·网络安全·web3·httpx
汽车仪器仪表相关领域1 小时前
NHFID-1000型非甲烷总烃分析仪:技术破局,重构固定污染源监测新体验
java·大数据·网络·人工智能·单元测试·可用性测试·安全性测试
咖啡忍者1 小时前
【SAP CO】4.COPC产品成本控制-3.WIP后台配置
笔记
上海云盾-小余1 小时前
DDoS 攻击全解析:常见类型识别与分层防御思路
网络协议·tcp/ip·安全·ddos
卤炖阑尾炎1 小时前
Python 网络编程实战:从 TCP/UDP 基础到高并发服务器开发
网络·python·tcp/ip
www4391 小时前
Vulinbox(敏感信息与敏感文件泄露)
安全