字单元:存放一个字型数据(16位)的内存单元,由两个地址连续的内存单元组成。
高地址内存单元中存放字型数据的高位字节,低地址内存单元中存放字型数据的低位字节。
任何两个地址连续的内存单元,N号和N+1号单元,可以将它们看成两个内存单元,也可以看成一个地址为N的字单元中的高位字节单元和低位字节单元。
接下来说明DS和[address]的使用姿势:
mov ax,1000H
mov ds,bx
mov al,[0]
分析:mov指令的功能:1.将数据直接送入寄存器;
2.将一个寄存器中的内容送入另一个寄存器;
3.将一个内存单元中的内容送入另一个寄存器中。(内存单元在指令中必须指出)
mov al,[0]中[…]中的0代表内存单元的偏移地址。而8086CPU会自动取ds中的数据为内存单元的段地址。
因为8086CPU不能将数据直接送入段寄存器,而ds寄存器是一个段寄存器,所以需要用一个寄存器进行中转。即可用:mov ds,bx
也可以使用,mov 段寄存器,内存单元 如:
mov ax,1000H
mov ds,ax
mov ds,[0]
将10000H处存放的字型数据送入ds
将数据从寄存器送入到内存单元中是:mov 内存单元地址,寄存器名
将数据从内存单元送入到寄存器中是:mov 寄存器名,内存单元地址
栈:先进后出
8086CPU中提供了出栈和入栈的指令,最基本的两个是PUSH(入栈)和POP(出栈)
如:PUSH AX表示将寄存器ax中的数据送入栈中,POP AX表示从栈顶取出数据送入ax。它们都是以字为单位进行的。
可以进行以下操作:
mov ax,1000H
mov ds,ax
push [0]
pop [2]
这样的操作引出了一个问题:CPU如何知道栈顶的位置?
8086中有两个寄存器:段寄存器SS和寄存器SP
类似于CS和IP,SS中存放的是栈顶的段地址,偏移地址存放在SP中。同时,任意时刻有:SS:SP指向栈顶元素。
PUSH指令的执行步骤:1.SP=SP-2;
2.向SS:IP指向的内存单元中送入数据。
POP指令的执行步骤:1.从SS:SP指向的字单元中读取数据;
2.SP=SP-2。
SS:IP指向栈顶元素,当栈为空时,栈中没有元素,也就不存在栈顶元素,所以SS:IP只能指向栈的最底部单元下面的单元,该单元的地址为栈最底部的字单元的地址+2.
一个栈的最大容量为64KB.
debug的T命令在执行修改寄存器SS的指令时,下一条指令也紧接着被执行。
内存地址空间的地址段分配如下:
1.地址0~7fffh的32kb空间为主随机存储器的地址空间;
2.地址8000~9fffh的8kb空间为显存地址空间;
3.地址a000h~ffffh的24kb空间为各个ROM的地址空间。
ROM地址空间内的数据是不会轻易改变的,所以不要试图向其中写入数据。