C语言内存编址
文章目录
- 一、总线
- 1.总线的含义
- 2.总线的分类
- ●**地址总线**
- ●**数据总线**
- ●**控制总线**
- 二、内存编址
- 2.1 内存按什么进行编址?
- 2.2 内存编址的意义?
一、总线
1.总线的含义
总线是计算机各种功能部件之间传送信息的公共通信干线,它是由导线组成的传输线束。总线是一种内部结构,它是CPU、内存、输入、输出设备传递信息的公共通道。主机的各个部件通过总线相连接,外部设备通过相应的接口电路再与总线相连接,从而形成了计算机硬件系统。在计算机系统中,各个部件之间传送信息的公共通路叫总线。
总线的特点[引用]:
●共享性
总线是供所有部件通信共享的,任何两个部件之间的数据传输都是通过共享的公共总线进行的。
●独占性
当一个部件占用总线与另一个部件进行数据通信时,其他部件就不能再占用总线。
2.总线的分类
按总线上传输信号的不同,总线可分为:[参考]:
●地址总线
地址总线是用于传递地址信息的总线。CPU(中央处理器)是通过地址总线来指定存储单元的,而内存是通过地址来管理的。CPU想从内存中的某个地址空间上存储一个数据,CPU就需要在地址总线上输出这个存储单元的地址。地址总线的宽度(地址总线根数)决定了CPU的寻址能力,也就是CPU能达到的最大地址范围。如果CPU有32根地址总线,每根地址总线上只能传输0(低电平)和1(高电平)两种电信号(计算机中数据是以二进制的形式存储),所以32根地址总线总共能传输232种信息,即CPU的寻址能力能达到232,CPU可以对232个存储单元进行寻址。所以如果一个CPU有N根地址线,那么就说这个CPU的地址总线的宽度就为N,CPU的寻址范围为0~2N,即CPU最多可以寻找232个内存单元[参考]。
●数据总线
CPU与内存或与其他器件之间的数据传输是通过数据总线来进行的。数据总线的宽度(数据总线的根数)决定了CPU与外界数据的传输速度。例如:8根数据总线一次即可传送8位(bit)二进制数据(一个字节);16根数据总线一次可传送16位二进制数据(两个字节)。
如8位数据总线:
CPU分两次传送数据89D8,第一次传送D8,第二次传送89:(89D8是16进制数,转换为二进制数为1000100100011011)16位数据总线一次即可传送完上面的数据89D8:
●控制总线
CPU对外部器件的控制是通过控制总线进行的。控制总线用于传输控制信号和指令信息。它负责将指令和控制信号从CPU发送到各个计算机组件,协调和控制计算机的操作。这里的控制总线是一些不同控制线的集合。有多少根控制总线,就意味着CPU提供了对外部器件的多少控制。如CPU对存储器的读、写控制信号等。
🎯总结三种总线的功能:
地址总线:用来传递地址信息。
数据总线:用来传递数据信息。
控制总线:用来发送各种控制信号。
二、内存编址
2.1 内存按什么进行编址?
如何理解计算机中内存是按照字节来进行编址的这句话[引用]?
内存是按字节进行编址的,每个字节的存储单元可以存放8bit的数据。我们也知道CPU通过内存地址获取一条指令和数据,而他们存在存储单元当中。我们的数据和指令可能刚好是8bit(1字节),也可能小于8位,顶多浪费几位(或许按照字节编址是为了节省内存空间考虑)。但当数据或指令的长度大于8bit,我们就需要使用多个存储单元来存放数据或指令。读取数据的时候,一次就可以读取多个内存单元。
2.2 内存编址的意义?
CPU访问内存中的某个字节空间,必须知道这个空间在内存的什么位置,而内存中的空间很大,所以需要给内存空间进行编址(就如同宿舍很多,需要给宿舍编号一样)。
