内存访问
1 字的存储
寄存器中:16位寄存器存一个字。高8位放高位字节,低8位当低位字节。
内存中:内存单元是字节单元,一个字要用2个连续的内存单元保存。低位字节保存在低地址内存单元,高位字节保存在高地址内存单元
0地址存放的字为20000(4E20H)
字单元:0、1两个内存单元用来存放一个字,这两个内存单元可以看成起始地址为0的字单元(存放一个字的单元,由两个内存单元组成)
2 段寄存器
DS寄存器是默认的段地址寄存器,在没有声明内存单元的段地址,只说明了偏移地址的时候自动调用DS中的短地址。
但是向DS寄存器中赋值只能将其他寄存器的值传入,不可以直接传入数字
3 mov指令
- mov 寄存器, 数据
- mov 寄存器, 寄存器
- mov 寄存器, 内存单元
- mov 内存单元, 寄存器
- mov 段寄存器,寄存器
4 栈
4.1 数据段
在编程时,可以根据需要,将一组内存单元定义为一个段。我们可以将一组长度为N(N<=64KB)、地址连续、起始地址为16 的倍数
的内存单元当作专门存储数据的内存空间,从而定义了一个数据段。
比如用123BOH~123B9H 这段内存空间来存放数据,我们就可以认为, 1 23 BOH~ 123B9H 这段内存是一个数据段,它的段地址为123BH , 长度为10 个字节
4.2 CPU的栈机制
8086CPU 中,有两个寄存器,段寄存器SS 和寄存器SP,栈顶的段地址存放在SS 中,偏移地址存放在SP 中。任意时刻, SS:SP 指向栈顶元素。
push 指令和pop 指令执行时, CPU 从SS 和SP 中得到栈顶的地址。
现在,我们可以完整地描述push 和pop 指令的功能了,例如push ax
push ax 的执行,由以下两步完成。
(1) SP=SP- 2, SS:SP 指向当前栈顶前面的单元,以当前栈顶前面的单元为新的栈顶;
(2)将ax 中的内容送入SS:SP 指向的内存单元处, SS : SP 此时指向新栈顶。
入栈时,栈顶从高地址位向低地址位增长
4.3 POP和PUSH
-
push 寄存器 将寄存器中数据存放到栈中
-
pop 寄存器 将寄存器接受出栈数据
-
push 段寄存器 将段寄存器数据放到栈中
-
pop 段寄存器 将出栈数据保存到段寄存器
-
push 内存单元 将一个内存字单元处的字入栈(注意: 栈操作都是以字为单位)
-
pop 内存单元 出栈, 用一个内存字单元接收出栈的数据
意: 栈操作都是以字为单位)
- pop 内存单元 出栈, 用一个内存字单元接收出栈的数据