主存中存储单元地址的分配

在阅读该文之前,建议读者事先了解了主存的基本组成:主存储器的基本组成
这样更容易理解

主存中存储单元:

下图中,每一个小方块就代表一个存储单元,大方块是主存中的存储体。
以8位二进制作为一个存储单元,也就是一个字节。
通常,字由字节组成。(说白了,字和字节都是一位一位构成的,只不过字包含了字节)
下图一个存储单元为一个字节,这4个字节又构成了1个字。每个字有字地址,在图中形象化的表示了。

那么现在一个问题是,下图的字长为多少?
经过分析,4个字节组成了1个字,一个字节8位,所以总共是32位,字长也就是32位。

示例图如下:
主存中存储单元地址的分配_第1张图片

例子:

了解了上面的概念原理,我们来做几个例子:

1.设地址线为24根,按字节寻址,求访问范围?
2.如果存储容量不变,若字长为16位,求按寻址范围?
3.如果存储容量还不变,若字长为32,求按寻址范围?

我们先分析第一个问题。
如果地址线有24根,并且每根地址线有0、1两位,我们可以从000…000(24位)一直到111…111(24位)。所以一共就有224位,也就是有224个地址。转化完成就是16M。这些地址表示存储单元的位置,所以存储单元的个数也为16M。

如何转换为16M:点击这里!!!

第一个问题说了,我们要按字节寻址,有多少存储字。
一个存储单元可以存放一个8位二进制数,这个二进制数就是一个存储字。说白了就是问有多少个存储单元。经过分析就有16M个。

 
关于存储容量:
一个存储单元中有8位,那么16M个存储单元(地址)中,可以存放16M×8位。这也就是存储容量

假如地址寄存器MAR是8位,每个存储单元可以写入/读出10位的二进制数。存储容量 就应该为28×10位。

 
 
字地址:用该字高位字节的地址表示。也有用低位字节的地址来表示字地址。
那么来看第二个问题:
存储容量不变,也就是有16M*8位,若字长为16位,我们按字寻址,有多少存储字。
下图的字长为16位:一个字节8位,两个字节自然就是16位。
主存中存储单元地址的分配_第2张图片
如果是按字寻址,我们知道字长16位,那么用总容量除以字长就是存储字的个数:

(16M*8)/16=8M

 
第二个懂了的话,第三就好懂啦,只不过是把16换为了32。
字长为32的存储:
主存中存储单元地址的分配_第3张图片
存储字的个数:

(16M*8)/32=4M

你可能感兴趣的:(计算机组成原理)