自学王爽老师《汇编语言》笔记——第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
#汇编语言##自学##读书笔记#