1、push指令
mov ax,0123H
PUSH AX
MOV BX,2266H
PUSH BX
POP BX
POP AX
每次往栈地址里放16b两个字节的数据
2、
问题一:CPU如何知道一段内存空间被当作栈使用
答案:寄存器CS IP中存放着当前指令的段地址和偏移地址
8086CPU中有两个寄存器:
段寄存器SS 存放栈顶的段地址
寄存器SP 存放栈顶的偏移地址
任意时刻 SS:SP 指向栈顶元素
<AX BX CX DX通用寄存器>
<CS DS SS ES段寄存器>
问题二:指行push和pop的时候,如何知道哪个单元是栈顶单元
执行PUSH AX
CPU内部执行了
(1)SP = SP - 2;
(2) 将ax中的内容送入SS:SP指向新的内存单元,SS:SP指向新的栈顶
问题三:
如果我们将10000H-1000FH这段栈空间当作栈,初始状态是空的,此时SS=1000H,SP=?到外面去了?
执行POP AX
(1)将SS:SP指向的内存单元处的数据送入AX中
(2) SP = SP + 2 SS:SP指向当前栈顶下面的单元为新的栈顶、
这里pop操作出栈后ss sp指向新的栈顶但是原来位置的数据依然存在知识不在栈中,push的时候会自动覆盖原来的数据
SS和SP的越界问题(JAVA不会)
满了push
空了pop。。。无法处理
栈段
在编程时可以根据需要将一组内存单元根据需要定义为一个段
将一段内存当作栈段,只是我们在编程时的一种安排,CPU只看得到栈顶指针
//
栈是怎么出来的呢,main函数里面调用其他函数你执行完了以后是要调回来的,这里就用到了栈,用栈来临时存放这些东西,用完就释放掉
数据段就是我们定义的存放数据的段代码段同样