堆栈操作指令

6、堆栈操作指令

**************************************************************************************************

   堆栈是按先进后出的的原则在内存中组织的一个存储区域。该区域一端固定一端活动,固定端称为栈底,而活动端称为栈顶。往堆栈中存入或取出信息都在栈顶进行。CPU中的堆栈指针SP始终指向栈顶,而堆栈段寄存器SS则指明了堆栈段的起始位置。

 

堆栈是一个重要的数据结构,它具有“先进后出”的特点,通常用来保存程序的返回地址。它主要有两大类操作:进/压栈操作和出/弹栈操作。

 

1)、进栈操作

 

PUSH

指令格式:PUSH Reg/Mem

PUSH Imm          

一个字进栈,系统自动完成两步操作:SP←SP-2,(SP)←操作数;

一个双字进栈,系统自动完成两步操作:ESP←ESP-4,(ESP)←操作数。

 

PUSHA

指令格式:PUSHA      

其功能是依次把寄存器AX、CX、DX、BX、SP、BP、SI和DI等压栈。

 

PUSHAD

指令格式:PUSHAD      

其功能是把寄存器EAX、ECX、EDX、EBX、ESP、EBP、ESI和EDI等压栈。

 

2)、出栈操作

POP

指令格式:POP Reg/Mem

弹出一个字,系统自动完成两步操作:操作数←(SP),SP←SP+2;

弹出一个双字,系统自动完成两步操作:操作数←(ESP),ESP←ESP+4。

 

POPA

指令格式:POPA       

其功能是依次把寄存器DI、SI、BP、SP、BX、DX、CX和AX等弹出栈。其实,程序员不用记住它们的具体顺序,只要与指令PUSHA对称使用就可以了。

 

POPAD

指令格式:POPAD    

其功能是依次把寄存器EDI、ESI、EBP、ESP、EBX、EDX、ECX和EAX等弹出栈,它与PUSHAD对称使用即可。

**************************************************************************************************

原文地址:https://www.cnblogs.com/dabiao/p/1953860.html