自学王爽老师《汇编语言》笔记——第7章 更灵活的定位内存地址
第7章 更灵活的定位内存地址的方法
7.1 and和or指令
指令 | 作用 |
---|---|
and指令 | 按位进行与运算 |
or指令 | 按位进行或运算 |
7.2 关于ASCLL码
计算机中,所有的信息都是二进制,而人能理解的信息是已经具有约定意义的字符。
7.3 以字符形式给出的数据
我们可以在汇编程序中,用 '...' 的方式指明数据是以字符的形式给出的,编译器将把它们转换为相应的ASCLL码。
; 例如下列用法 data segment db 'UNIX' data ends mov al,'a'
7.4 大小写转换的问题
大写 | 十六进制 | 二进制 | 小写 | 十六进制 | 二进制 | |
---|---|---|---|---|---|---|
A | 41 | 01000001 | a | 61 | 01100001 | |
B | 42 | 01000010 | b | 62 | 01100010 | |
C | 43 | 01000011 | c | 63 | 01100011 | |
D | 44 | 01000100 | d | 64 | 01100100 | |
... | ... | ... | ... | ... | ... |
- 小写字母的ASCLL码值比大写字母的ASCLL码值大20H。
- 大小写字母的ASCLL码除第5位(从0开始)之外其余位相同。大写第五位为1,小写为0。
7.5 [bx + idata]
除了 [bx] 还可以用以下的方式来指明内存单元:
- mov ax,[bx + idata]
- mov ax,[idata + bx]
- mov ax,idata[bx]
- mov ax,[bx].idata
7.6 用 [bx + idata] 的方式进行数组的处理
- C语言: a[i], b[i]
- 汇编语言:0[bx],5[bx]
通过比较,我们可以发现,[bx + idata] 为高级语言实现数组提供了便利机制。
7.7 SI和DI
si 和 di 是 8086CPU 中和 bx 功能相近的寄存器,si 和 di 不能够分成两个8位寄存器来使用。
7.8 [bx + si] 和 [bx + di]
- [bx + si] 含义如下:((ds) * 16 + (bx) + (si))。di 同理。
- 另一种写法(常用):[bx][si]
7.9 [bx + si + idata] 和 [bx + di + idata]
- [bx + si + idata] 含义如下:((ds) * 16 + (bx) + (si) + idata)。di 同理。
- 另几种写法(常用):
- idata[bx][si]
- [bx].idata[si]
- [bx][si].idata
7.10 不同寻址方式的灵活应用
具体用法:
- [idata]用一个常量来表示地址,可以用于直接定位一个内存单元;
- [bx]用一个变量来表示内存地址,可用于间接定位一个内存单元;
- [bx + idata]用一个变量和常量表示地址,可在一个起始地址的基础上用变量间接定位一个内存单元;
- [bx + si]用两个变量表示地址;
- [bx + si + idata]用两个变量和一个常量表示地址。
一般来说,在需要暂存数据的时候,我们都应该使用栈。
实验六 实践课中的程序
assume cs:code, ss:stack, ds:data stack segment dw 0,0,0,0,0,0,0,0 stack ends data segment db '1. display ' db '2. brows ' db '3. replace ' db '4. modify ' data ends code segment start: mov ax,stack mov ss,ax mov sp,16 mov ax,data mov ds,ax mov bx,3 mov cx,4 s: push cx mov cx,4 mov si,0 s0: mov al,[bx + si] or al,00100000B mov [bx + si],al inc si loop s0 add bx,16 pop cx loop s mov ax,4c00h int 21h code ends end start#汇编语言##自学##读书笔记#