第五章 [BX]和loop
1.内存单元间接表示: [bx]
mov dl, [0]; dl ← ((ds)×16 + 0)
mov bx, 0
mov dl, [bx]; dl ← ((ds)×16 + (bx))
可以使用bx间接访问内存单元。默认,段地址在ds。
2.loop指令
(1) 语法格式
loop 标号
(2) CPU执行指令过程
① (cx) ← (cx) - 1
② 判断cx的值是否为0。 如果(cx) ≠ 0,跳转到标号处执行; 如果(cx) = 0, 执行loop后面的其它指令。
3.段前缀
mov dl, [6]; dl ← ((ds)×16 + 6)
mov ax, [bx]; ax ← ((ds)×16 + (bx))
默认情形下,无论是直接给出的偏移地址,还是通过bx间接给出的偏移地址,都是取ds的值作为段地址来计算物理地址。 可以通过增加「段前缀」改变默认状况。
4.安全内存空间
计算机系统内存的使用并不是任意的,有些内存单元有专用用途,保留有系统重要数据。
① 在8086模式中,00200h ~ 002ffh这段空间一般不会被使用,视作用户可自由使用的安全空间。
② 现代操作系统大多使用CPU保护模式对内存使用进行管理,限制用户非法访问一些关键内存空间。
第六章 包含多个段的程序
① 使用伪指令segment和ends定义逻辑段后,究竟是用作代码段、数据段还是栈,由程序员指定。
② 使用assume仅仅表示将某个逻辑段和某个段寄存器关联起来;真正当作特定的段使用,需要在代码段中设置相应的段寄存器值,如ds, ss。
③ 段名代表的是段地址,是常数。不能使用mov直接送入段寄存器。
第七章 更灵活的定位内存地址方法
1.汇编指令: and和or
and指令:① and指令语法格式及对操作数要求与add指令同
② 可以实现将操作数指定位设置为0
or指令:① or指令语法格式及对操作数要求与add指令同
② 可以实现将操作数指定位设为1
2.汇编中的字符处理
在汇编源程序中:既可以使用诸如‘a‘这样的字符写法,也可以使用ASCⅡ码形式的写法。
在debug中: a命令中不支持诸如‘a‘这样的写法
e命令中支持诸如‘a‘这样的写法,也支持ASCⅡ码形式的写法
3.其它灵活的内存地址表示
用[bx + idata]表示表示内存单元。idata表示常数。
用[si]表示表示内存单元。
用[si + idata]表示表示内存单元。idata表示常量。
用[di]表示表示内存单元。
用[di + idata]表示表示内存单元。idata表示常量。
用[bx+di], [bx+si]表示表示内存单元。
用[bx+di+idata], [bx+si+idata]表示表示内存单元。
第八章 数据处理的两个基本问题
1.汇编指令中操作数的类型
常数位于cpu内部,指令缓冲器;寄存器位于cpu内部,寄存器;内存单元位于cpu外部,内存
2.汇编指令中内存单元操作数的地址表示
在8086中,可用于表示内存偏移地址的寄存器只有: BX, SI, DI和BP。
这些寄存器可以单个出现在[]中,也可以以特定组合方式出现。
使用BX, SI, DI表示偏移地址时,默认段地址在DS中;
使用BP表示偏移地址时,默认段地址在SS中。
3.汇编伪指令: db, dw, dd, dup
data segment
db 1,2,3; 每个数据分配1个字节
dw 1,2 3; 每个数据分配2个字节
dd 1,2,3; 每个数据分配4个字节
data ends
data segment
db 0,0,0,0,0,0,0,0
db 8 dup(0); 预留8个字节单元,每个单元值为0
dd 8 dup(?); 预留8个字节单元,每个单元值未分配
data ends