• 3 内存访问


    内存访问

    1 字的存储

    寄存器中:16位寄存器存一个字。高8位放高位字节,低8位当低位字节。

    内存中:内存单元是字节单元,一个字要用2个连续的内存单元保存。低位字节保存在低地址内存单元,高位字节保存在高地址内存单元

    0地址存放的字为20000(4E20H)

    字单元:0、1两个内存单元用来存放一个字,这两个内存单元可以看成起始地址为0的字单元(存放一个字的单元,由两个内存单元组成)

    2 段寄存器

    DS寄存器是默认的段地址寄存器,在没有声明内存单元的段地址,只说明了偏移地址的时候自动调用DS中的短地址。

    但是向DS寄存器中赋值只能将其他寄存器的值传入,不可以直接传入数字

    3 mov指令

    • mov 寄存器, 数据
    • mov 寄存器, 寄存器
    • mov 寄存器, 内存单元
    • mov 内存单元, 寄存器
    • mov 段寄存器,寄存器

    4 栈

    4.1 数据段

    在编程时,可以根据需要,将一组内存单元定义为一个段。我们可以将一组长度为N(N<=64KB)、地址连续、起始地址为16 的倍数
    的内存单元当作专门存储数据的内存空间,从而定义了一个数据段。

    比如用123BOH~123B9H 这段内存空间来存放数据,我们就可以认为, 1 23 BOH~ 123B9H 这段内存是一个数据段,它的段地址为123BH , 长度为10 个字节

    4.2 CPU的栈机制

    8086CPU 中,有两个寄存器,段寄存器SS 和寄存器SP,栈顶的段地址存放在SS 中,偏移地址存放在SP 中。任意时刻, SS:SP 指向栈顶元素。

    push 指令和pop 指令执行时, CPU 从SS 和SP 中得到栈顶的地址。

    现在,我们可以完整地描述push 和pop 指令的功能了,例如push ax
    push ax 的执行,由以下两步完成。
    (1) SP=SP- 2, SS:SP 指向当前栈顶前面的单元,以当前栈顶前面的单元为新的栈顶;
    (2)将ax 中的内容送入SS:SP 指向的内存单元处, SS : SP 此时指向新栈顶。

    在这里插入图片描述

    入栈时,栈顶从高地址位向低地址位增长

    4.3 POP和PUSH

    • push 寄存器 将寄存器中数据存放到栈中

    • pop 寄存器 将寄存器接受出栈数据

    • push 段寄存器 将段寄存器数据放到栈中

    • pop 段寄存器 将出栈数据保存到段寄存器

    • push 内存单元 将一个内存字单元处的字入栈(注意: 栈操作都是以字为单位)

    • pop 内存单元 出栈, 用一个内存字单元接收出栈的数据

    意: 栈操作都是以字为单位)

    • pop 内存单元 出栈, 用一个内存字单元接收出栈的数据
  • 相关阅读:
    【大数据】Kafka 入门指南
    基于Qt中操作MySQL数据库示例
    Excel数据格式:XLSX vs CSV 使用Python处理数据的优劣比较
    常见的请求头,怎么用?
    NLP基本业务范围
    5 分钟带你小程序入门 [实战总结分享]
    2023 IDC中国数字金融论坛丨中电金信向行业分享“源启+应用重构”新范式
    基于RV1126 Video分析-----图像处理模块所代表的V4L2设备注册
    布兰德 • 斯奈德节拍表
    【Spring】Day19
  • 原文地址:https://blog.csdn.net/m0_56773049/article/details/128193136