作者:手机用户2602919547 | 来源:互联网 | 2023-05-17 03:28
现代存储器基本存储单元都是以字节为单位,这样就设立了按字节来编号地址,如000代表0地址,001代表了1地址……,这样一个个按字节为单位的空间组成了整个大的存储器所谓的按字节都取就是,给第一个地
现代存储器基本存储单元都是以字节为单位, 这样就设立了按字节来编号地址,如000代表0地址,001代表了1地址……,这样一个个按字节为单位的空间组成了整个大的存储器
所谓的按字节都取就是,给第一个地址编号,CPU从存储器相对应的地址编号中读取一个字节的数据。
下面来说下按字读取,字是一个不定大小的存储量,我们可以说2个字节为一个字,4个字节,8个字节等为一个字。虽然这样但是针对每个存储器当然也不会随意乱编一通。我们知道存储器是由一个个存储芯片构成,而每个存储器位宽通常是一个字节,那么假如现在生产一款存储器一次性要读取8个字节,那么我们会将8个1字节位宽的存储芯片并联, 这样原来给一个地址只能读取一个字节的,就变成8个字节了,而这个一次性就能取到的8字节就是代表当前这个存储器的一个字
那如果按字读取,我们传递的地址又会是多少呢? 我想想象一下存储器的存储空间是一个 矩阵 ,针对上面这个存储器,每行是8列,读取一行就是8个字节了,我们只要给定每行的第一列的地址就可以获取整行了,当然这个时候你也许会问为什么不会读取第一行第一列呢,
这个时候其实还会有一个信号来控制,暂时不讨论。 第一行的开头是00000,第二行是01000,第三行是10000,第4行是11000,也就是8 的倍数地址。其实我们可以看出,这样一个地址,后面的3位其实没什么多大作用了,不用来参与寻找地址了。
也就是实际上如果按字读取数据的时候,地址是由从由往左第4位开始 及以上高位的地址编号决定了读取哪个字。