汇编语言(第3版)- [BX]和loop指令

[BX]和loop指令


在这里插入图片描述

[BX]

就是间接寻址。

[0] 表示 偏移地址为0

[BX] 表示内存的偏移地址 存放在BX寄存器中。

mov ax, [bx] # (ax) = ((ds)*16+(bx))

有一点需要说明:

在源程序中使用 mov ax, [0] 会被MASM编译器 编译成move ax,0, 所以不得不借助于bx寄存器。

mov bx,0
mov ax, [bx]

Loop指令

loop标号:

  1. (cx) = (cx)-1
  2. 如果cx==0, 向下执行,否则跳转到标号处执行。

简而言之 就是实现 循环(cx)次 标号处的命令。

在Debug中跟踪用loop指令实现的循环程序。

在源程序中 数字不能以字母开头。

所以B001H 得写成0B001H

使用g 可以执行到指定的代码处。

使用p可以执行完循环体。

Debug和汇编编译器masm对指令的不同处理

略,

就是debug中可以用mov ax,[0]

同样的指令在masm会编译成mov ax, 0

在源代码中实现类似的功能,有两种方法:

 # 间接寻址
   mov bx,0
   mov ax,[bx]

# 直接寻址
   mov ax, ds:[0]

loop和[bx]的联合应用

略,就是个举例。

段前缀

默认的段地址存放在ds中,

程序也可以指定 具体的寄存器。如mov ax, es:[bx], 这个就是 (ax) = ((es)*16+(bx))

这个出现在访问内存单元的指令中,用于显示地指明内存单元的段地址的"es", 在汇编语言中称为 段前缀

一段安全的空间

dos环境下(实模式),可以绕过操作系统,直接对任意的内存写数据,而改写的内存可能存放的系统数据,其他程序的数据。会引发异常,安全的编程就是只能在系统分配的内存空间范围内操作。

在windows2000,unix等运行于cpu保护模式下的系统,汇编语言已经无法直接操作硬件。

dos方式下,一般不会使用0:200~0:2ff 的256个字节的空间,使用前可以先看看数据是不是都是0,都是0就表示是安全的。

段前缀的使用

略。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值