1.栈
栈有两个基本的操作:入栈和出栈。入栈就是将一个新的元素放到栈顶,出栈就是从栈顶取出一
个元素。栈顶的元素总是最后入栈,需要出栈时,又最先被从栈中取出。栈的这种操作规则被称为:
LIFO(Last In First Out)。
2.CPU提供的栈机制
8086CPU提供入栈和出栈指令,最基本的两个是PUSH(入栈)和POP(出栈)。在8086CPU中,有
两个寄存器,段寄存器SS和寄存器SP,栈顶的段地址存放在SS中,偏移地址存放在SP中,让人一时刻
,SS:SP指向栈顶元素。push指令和pop指令执行时,CPU从SS和SP中得到栈顶的地址。
如执行push ax指令时:
(1)SP=SP-2,ss:sp指向当前栈顶前面的单元,以当前栈顶前面的单元为新的栈顶;
(2)将ax中的内容送入SS:SP指向的内存但远处,SS:SP此时指向新栈顶
8086CPU中,入栈时,栈顶从高地址向低地址方向增长。
如执行POP ax指令时:
(1)将SS:SP指向的内存单元出的数据送入ax中;
(2)SP=SP+2,SS:SP指向当前栈顶下面的单元,以当前栈顶下面的单元为新的栈顶。
用栈来暂存以后需要回复的寄存器的内容时,寄存器出栈的顺序要和入栈的顺序相反。
3.栈顶超界的问题
栈顶超界是为向的,因为我们既然将一段空间安排为栈,那么在栈空间之外的地址可能存放了具
有其他用途的数据、代码等,这些数据、代码可能是我们自己程序中的,也可能是别的程序中的,但
是由于我们入栈出栈时的不小心,而将这些数据、代码以外地改写,将会引发一连串的错误。
不过,8086CPU中并没有提供可以记录栈顶上线和栈底的寄存器,所以,8086CPU不保证我们对栈
的操作不会超界。这也就是说,8086CPU只知道栈顶在何处(由SS:SP指示),而不知道要执行的指令
有多少。从而得知8086CPU的工作机理,只考虑当前的情况。
所以在编程时要自己操心栈顶超界的问题,要根据可能用到的最大栈空间,来安排栈的大小。
4.push、pop指令
push和pop的指令歌手可以如下:
push 寄存器 ;将一个寄存器中的数据入栈
pop 寄存器 ;出栈,用一个寄存器接受出栈的数据
push 段寄存器 ;将一个段寄存器中的数据入栈
pop 段寄存器 ;出栈,用一个段寄存器接受出栈的数据
push 内存单元 ;将一个内存单元处的字入栈(栈操作都是以字为单位)
pop 内存单元 ;出栈,用一个内存字单元接受出栈的数据
push、pop实质上是一种内存传送指令。
4.栈段
我们可以将长度为N(N小于等于64KB)的一组地址连续、起始地址为16的倍数的内存单元,单做栈空
间来用,从而定义了一个栈段。
- [游客] 石职wsd专升本da卡 11/18 15:28
- [游客] 石职wsd专升本da卡 11/18 15:28
- [游客] 似乎这个站点没有什么新鲜的活力了 07/23 18:22
- [游客] 博主有没有学习群 07/23 19:14
- [游客] 可以的 07/23 19:13
- [游客] aaaaaaaaaaaa 09/19 13:49
- [jinshuwen] 很有收获! 01/19 16:25
- [hujie0421] 谢谢分享 02/01 05:14
- [jiejie] 来学习一下 10/01 11:31
- [yexueyao] 谢谢,我是学习计算机专业的,汇编语言一学期几乎没听懂过,看你的日记,很有帮助,我会加油学的,期末要拿 11/12 10:14
- [游客] 嘉義定點外約Line: a57963#嘉義學生妹外約 桃園中壢外送茶Line: a57963#中壢外 11/29 15:39
- [游客] 嘉義定點外約Line: a57963#嘉義學生妹外約 桃園中壢外送茶Line: a57963#中壢外 11/29 15:39
- [游客] 嘉義定點外約Line: a57963#嘉義學生妹外約 桃園中壢外送茶Line: a57963#中壢外 11/29 15:38
- [游客] 嘉義定點外約Line: a57963#嘉義學生妹外約 桃園中壢外送茶Line: a57963#中壢外 11/29 15:38
- [bingfeixue] masm32 汇编器具体怎么用啊 04/28 09:24