汇编:关于栈的知识

1.入栈和出栈指令

[2. SS与SP](#2. SS与SP)

[3. 入栈与出栈](#3. 入栈与出栈)

[3.1 执行push ax ↑↑](#3.1 执行push ax ↑↑)

[3.2 执行pop ax ↓↓](#3.2 执行pop ax ↓↓)

[3.3 栈顶超界的问题](#3.3 栈顶超界的问题)

[4. 寄存器赋值](#4. 寄存器赋值)


基于8086CPU编程时,可以将一段内存当作栈来使用。一个栈段最大可以设为64KB(0-FFFFH)。

1.入栈和出栈指令

  • push(入栈)
  • pop (出栈)

--- push ax:将寄存器ax中的数据送入栈中

--- pop ax:从栈顶 取出数据送入 ax

--- 入栈和出栈操作都是以【 (16位)】为单位进行

--- pop和push可以在寄存器和内存之间传送数据

2. SS与SP

8086CPU中,有两个寄存器

  • SS:段寄存器,存放栈顶段地址
  • SP:寄存器,存放栈顶偏移地址【专用寄存器】

任意时刻SS:SP指向栈顶元素。

若栈为空,sp指向最高地址单元的下一个单元。

3. 入栈与出栈

栈顶是低地址单元, 栈底是高地址单元。

3.1 执行push ax ↑↑
  • sp=sp-2(偏移地址减少,即往低地址处偏移栈顶方向)
  • 将ax中的内容送入到ss:sp指向的内存单元
  • ss:sp此时指向新栈顶
3.2 执行pop ax ↓↓
  • 将ss:sp指向的内存单元的内容送入到ax中(取出的内容在内存中仍存在,并没有被重置,下一轮push会覆盖)
  • sp=sp+2(偏移地址增加,即往高地址处偏移栈底方向)
3.3 栈顶超界的问题

8086CPU没有记录栈顶上下限的寄存器,不保证栈的操作不会越界。栈空时pop出栈或当栈满时push入栈都会发生栈顶超界问题,操作到栈以外的数据。

4. 寄存器赋值

关于cs、ip、ss、sp、ds的赋值:

  • 可以通过mov直接给sp赋值【立即数寻址】
  • 不能通过mov给cs、ip、ss、ds赋值
  • 给cs和ip赋值需要使用jum指令
  • 给ss和ds赋值需要使用mov ss/ds, 寄存器;【寄存器寻址】
相关推荐
鹏北海-RemHusband2 小时前
Go 语言进阶笔记 — 面向 JS/TS 前端开发者
笔记·golang
nnsix3 小时前
Unity QFramework ResKit、UIKit 笔记
笔记
摇滚侠4 小时前
Java 零基础全套教程,反射机制,笔记 187-188
java·开发语言·笔记
【云轩】4 小时前
如何设计一台能模拟电机的电子负载:一个硬件工程师的实战笔记
笔记·嵌入式硬件
可信计算6 小时前
X司民用无人机运行安全与合规培训手册
笔记
李子琪。6 小时前
Web漏洞-CSRF-CSRF防御 实验步骤
经验分享·笔记
小碗羊肉7 小时前
【Agent笔记 | 第四篇】Agentic RAG
笔记
小雨xs8 小时前
Vulnhub靶场DC-9 渗透测试笔记
笔记
whyTeaFo8 小时前
MIT 6.1810: xv6 book Chapter3: Page tables 笔记
笔记
東雪木9 小时前
JVM 与 Java 内存模型 专属复习笔记
java·jvm·笔记·java面试