博客
关于我
学汇编,记笔记(四)_《汇编语言(第4版)》王爽著——[BX]和loop
阅读量:793 次
发布时间:2019-03-25

本文共 1672 字,大约阅读时间需要 5 分钟。

前言

bloquefxnxiazaiFOX《汇编语言(第4版)》王爽著。本笔记是课本内容+自我整理,便于查阅与复习。支持原著。

约定符号

[0]表示偏移地址为0的内存单元,有自适应功能: - `mov ax, [0]`:将字单元[0]和[1]拷贝到ax - `mov al, [0]`:将字节单元[0]拷贝到al

同理,[bx]表示偏移地址为bx的内存单元,此时偏移空间存在bx内。

注意:只有bx、bp、si、di四个寄存器可用[]形式寻址。

  • (bx)表示bx存储的内容,可以是寄存器(ax)、段寄存器+偏移地址((ds)*16+(bx))或内存单元(10000H)。
  • (2000:0)等错误用法需统一,前后保持一致。

idata表示任意常量,可取1, 2, 3, ...。

文章目录

(此处目录格式暂空)

一、loop 指令

loop指令用于循环操作,循环次数由寄存器cx存储。格式为`loop 标号`,循环入口需标注。

例如:

assume cs:calcal segment  mov ax, 1  mov cx, 2  ;循环体  s: add ax, ax  loop s  ;返回值  mov ax, 4c00h  int 21h  test ends end

loop指令执行步骤:(cx)-=1,判断cx是否为0。不为0则转至标号位置执行,否则继续下行。

实验:123 × 236 加法循环计算

累加123个236即得结果。 ```asm assume cs:calcal segment mov ax, 0 mov cx, 123 s: add ax, 236 loop s mov ax, 4c00h int 21h cal ends end ```

二、遍历连续内存单元

要遍历FFFF:0~FFFF:B内存单元(共十二个单元),可以用循环代替繁琐的add语句。 注意:内存单元以字节为单位,ax为十六位寄存器,存储单元长度与寄存器位数不同,需分别设置高字节和低字节。 - ah需初始化为0,al则设置为FFFF:[bx]。 - 汇编源程序中数据不能以字母开头,FFFF需写成0FFFFH。

代码示例:

assume cs:ffff0_12 segment  mov ax, 0FFFFh  mov ds, ax  mov bx, 0  mov cx, 12  mov dx, 0  s: mov al, [bx]     mov ah, 0     add dx, ax     inc bx  loop s  mov ax, 4c00h  int 21h  ffff0_12 ends end

三、Debug.exe与MASM 的区别

对于`mov ax, [0]`,MASM会优化为`mov ax, 0`,而Debug.exe会解释为`mov ax, ds:0`。 为避免歧义,建议加上段前缀: - `mov al, ds:[0]` 对应al = (ds)*16 + 0 - `mov al, [bx]` 对应al = (ds)*16 + bx

四、段前缀的使用

为了明确偏移地址的来源,建议在所有偏移地址处加上段前缀: - `mov ax, ds:[bx/0]` - `mov ax, cs:[bx/0]` - `mov ax, ss:[bx/0]` - `mov ax, es:[bx/0]`

五、安全的内存使用

在PC机DOS模式下,安全的空闲内存区间为00200H~002FFH,共256字节。操作前请用Debug查询空闲内存,确保全为0后再使用。

六、Debug 调试loop

- `g (偏移地址)`:跳转至指定行运行,断点在该行之前的代码。 - `p`:执行一次loop循环,需先跳转至loop行。

后记:

  • 节目中发现段名不能命名为test(疑问)。
  • loop原理:cx减一后检查是否为0。循环次数由cx存储。
  • 良好习惯:段前缀的使用。
  • 避免随意写入内存。
  • 内存单元至寄存器需分段赋值以避免进位丢失。

转载地址:http://yvpuk.baihongyu.com/

你可能感兴趣的文章
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>
MySQL DBA 进阶知识详解
查看>>
Mura CMS processAsyncObject SQL注入漏洞复现(CVE-2024-32640)
查看>>
Mysql DBA 高级运维学习之路-DQL语句之select知识讲解
查看>>
mysql deadlock found when trying to get lock暴力解决
查看>>
MuseTalk如何生成高质量视频(使用技巧)
查看>>
mutiplemap 总结
查看>>
MySQL DELETE 表别名问题
查看>>
MySQL Error Handling in Stored Procedures---转载
查看>>
MVC 区域功能
查看>>
MySQL FEDERATED 提示
查看>>