【汇编】内存的读写与地址空间、寄存器及数据存储

文章目录


前言

在计算机体系结构中,内存的读写操作是一项关键任务,涉及到程序的执行、数据的存储和处理。同时,理解地址空间的概念对于编写有效的程序至关重要。本文将探讨汇编语言中的内存读写过程以及地址空间的概念,帮助读者更深入地理解计算机内部的运作机制。


一、CPU对存储器的读写

1.1 cpu对存储器的读写如何进行?

CPU要想进行数据的读写,必须和外部器件进行三类信息的交互:

存储单元的地址

(地址信息)

器件的选择,读或写命令

(控制信息)

读或写的数据

(数据信息)

1.2 演示

机器码: 101000000000001100000000

16进制:A00300

汇编指令:MOV AL,[3]

含义:从3号单元读取数据送入寄存器AL

首先,要读取的地址信息先进入内存找到对应的数据存储单元。找到了3,里面的数据为08

接下来,控制器发出读质量。3号单元的08顺着数据线给了我们存放数据的器件

二、内存地址空间

什么是内存地址空间

CPU地址总线宽度为N,寻址空间为2NB

8086CPU的地址总线宽度为20,那么可

以寻址1MB个内存单元,其内存地址空

间为1MB。

从CPU角度看地址空间分配:

三、将各类存储器看作一个逻辑存储器------统一编址

所有的物理存储器被看作一个由若干存储

单元组成的逻辑存储器;

每个物理存储器在这个逻辑存储器中占有

一个地址段,即一段地址空间;

CPU在这段地址空间中读写数据,实际上

就是在相对应的物理存储器中读写数据。

内存地址空间的分配方案

三、CPU的组成

运算器进行信息处理;

寄存器进行信息存储;

控制器协调各种器件

进行工作;

内部总线实现CPU内

各个器件之间的联系。

寄存器是CPU内部的信息存储单元

8086CPU有14个寄存器:

通用寄存器:AX、BX、CX、DX

变址寄存器:SI、DI

指针寄存器:SP、BP

指令指针寄存器: IP

段寄存器:CS、SS、DS、ES

标志寄存器:PSW

共性

8086CPU所有的寄存器都是16位的,

可以存放两个字节

通用寄存器--AX为例

一个16位寄存器存储一个16位的数据

最大值?

2^16-1

即是所有位都写1

例:在AX中存储18D

18D

--- 12H

--- 10010B

再例:在AX中存储20000D

20000D

--- 4E20H

--- 0100111000100000B

"横看成岭侧成峰"

问题

8086上一代CPU中的寄存器都是8位的,如何保证程序的兼容性?

方案

通用寄存器均可以分为两个独立的

8位寄存器使用

如下面这样:

细化

AX可以分为AH和AL

BX可以分为BH和BL

CX可以分为CH和CL

DX可以分为DH和DL

四、"字"在寄存器中的存储

4.1 "字"是什么东西?

当我们谈论计算机存储中的"字",它其实就是一种计量单位,用来描述在计算机中处理的数据大小。一个字通常由一串二进制数字组成,它可以是8位(一个字节)、16位、32位或者64位长,具体取决于计算机体系结构。

寄存器是计算机内部的小而快速的存储空间,就像大脑中的速记本。这里的"字"是指寄存器可以一次性处理的数据单元大小。比如,一个16位的寄存器可以存储或处理16位长的数据,而一个32位的寄存器可以处理更长的数据。

在寄存器中,字按照其长度被存储和处理。就像小抽屉里能容纳的物品大小不同一样,不同长度的字在寄存器中占据的空间也不同。这些"抽屉"以二进制形式存储数据,所以一个8位的寄存器可以容纳8个二进制位,而16位寄存器则能容纳16个,以此类推。计算机通过这些位来存储和处理数字、字符、图像或者指令等各种信息。

4.2 在8086中

8086是16位CPU

8086的字长(word size)为16bit

一个字(word)可以存在一个16位寄存器中

这个字的高位字节存在这个寄存器的高8位寄存器

这个字的低位字节存在这个寄存器的低8位寄存器


总结

内存的读写与地址空间是计算机体系结构中的核心概念。通过汇编语言,程序可以直接操作内存,实现对数据的灵活控制。地址空间的概念则为程序提供了一个有序的内存结构,使得不同部分的数据有序地存储在内存中。深入理解这些概念,有助于程序员编写出更高效、可靠的程序,充分利用计算机的内存资源。在今后的学习和开发过程中,对于内存和地址空间的理解将发挥重要作用。

相关推荐
mzhan0173 分钟前
Linux: config: CRYPTO_USER_API_AEAD
linux·安全·module
wangjialelele8 分钟前
【SystemV】基于建造者模式的信号量
linux·c语言·c++·算法·建造者模式
MXsoft61815 分钟前
**智能运维如何实现全栈监控与****AI****告警?****——****一体化平台实战解析**
运维·人工智能
MXsoft61821 分钟前
**运维体系升级:筑牢企业数字化转型的稳定底座**
运维
MXsoft61828 分钟前
**一体化智能运维如何破解跨区域****IT****管理****难题****?**
运维
不做无法实现的梦~35 分钟前
86步进电机和DM860H驱动器的使用方法和记录
单片机·嵌入式硬件
源远流长jerry1 小时前
Linux 网络虚拟化深度解析:从 veth 设备对到容器网络实战
linux·运维·服务器·网络·性能优化·php
朔北之忘 Clancy1 小时前
2026 年 3 月青少年软编等考 C 语言一级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·一级
Aaron15881 小时前
RFSOC+VU13P/VU9P+GPU多通道同步一体化解决方案
人工智能·嵌入式硬件·算法·matlab·fpga开发·硬件架构·基带工程
|_⊙1 小时前
Linux 深入理解文件(Ext2文件系统:上)
linux·运维·数据库