汇编6——栈

栈是一段计算机内存,遵循后进先出(LIFO)的原则。

 

8086CPU对栈的操作主要有入栈和出栈,分别对应PUSH 和 POP 指令。8086CPU的入栈和出栈操作都是以字为单位进行的。

段寄存器SS存放栈的段地址,SP寄存器存放栈的偏移地址,任意时刻,SS:SP指向栈顶元素。push指令和pop指令执行时,CPU从SS何SP种得到栈顶的地址。

 

push、POP指令的用法及功能:

PUSH/POP 寄存器/段寄存器/内存单元   ——表示把寄存器/段寄存器/内存单元中的内容压入栈中/从栈中取出。

PUSH AX  等价于  SP=SP-2; MOV [SS*16+SP], AX ;

POP  AX  等价于  MOV AX,[SS*16+SP];SP=SP+2;

 

栈顶超界问题

SS:SP始终指向栈顶元素,当栈为空的时候,也就不存在栈顶元素,此时SP指向栈的最底部单元的下面的单元,该单元的偏移地址为栈最底部的字单元的偏移地址+2.

栈顶超界发生在当栈满的时候再使用push指令入栈,或栈空的时候再使用pop指令出栈。

对8086CPU而言,CPU只知道栈顶的位置,却不知道栈空间有多大,所以栈顶超界问题是存在的,一旦发生,那么栈空间之外的代码、数据可能会被覆盖重写,将会引发一连串的错误。

你可能感兴趣的:(汇编)