cpu中,用16位寄存器来存储一个字,高8位存放再高位字节,低8位存放再低字节,在内存中存储时,由于内存单元是连续的,则一个字要用两个地址连续的内存单元存放
DS和[address]
CPU要读取一个内存单元的时候,必须先给出这个内存单元的地址,在8086cpu中,内存地址由段地址和偏移地址组成,8086cpu中DS寄存器,通常用来存放访问数据的段地址,例如我们要访问1000H单元的内存
mov ax,1000H
mov ds ,ax
mov al ,[0]
[…]表示一个内存单元,[…]中的0表示内存单元的偏移地址。
栈机制
学过数据结构的都知道栈的最打特性是先进后出,push表示压栈,也就是进栈,pop表示出栈,cpu为了能够准确的定位栈顶,所以使用了ss和sp两个寄存器来表示,ss寄存器表示栈的基地址,sp表示偏移地址,
push指令表示压栈,push ax的执行步骤是:
(sp) = (sp)-2
向ss:sp指向的字单元传送数据,这里ss:sp可以理解为传送数据的首地址
pop指令是表示出栈,pop ax执行步骤是:
从ss:sp地址指向的数据读取到ax中,
(sp) = (sp)+2
在使用栈的过程中,cpu并没有检测栈的边界,所以在使用过程中需要程序员自己去把控