图解计算机的存储器金字塔

2022-11-15  本文已影响0人  彭旭锐

前言

大家好,我是小彭。

在计算机组成原理中的众多概念中,开发者接触得最多的还是内存、硬盘、虚拟内存、CPU 缓存这些概念。这些概念有一个更为抽象的表示 —— 存储器,它是冯 · 诺依曼计算机体系中的五大组件之一,用于存储程序和数据。

在这个系列中,我将从存储器的金字塔结构展开,围绕 CPU 高速缓存、内存、硬盘、虚拟内存等内容逐步带你深入理解计算机中。


学习路线图:


1. 局部性原理

局部性原理是用于制定存储器系统数据管理策略的一个理论基础,我们可以分为 2 个维度来理解:

在计算机组成原理中,很多策略中都会体现到局部性原理,我们在学习中可以有意识地关联起来。例如在管理 CPU 高速缓存时,除了可以将当前正在访问的内存数据加到到缓存中,还可以把相邻内存的数据一并缓存起来(即 CPU 缓存行),也能够提高缓存命中率。


2. 认识存储器系统

2.1 为什么存储器系统要分层?

小伙伴们应该都知道内存和硬盘都是存储器设备。其实,在 CPU 内部中的寄存器和 CPU L1/L2/L3 缓存也同样是存储设备,而且它们的访问速度比内存和硬盘快几个数量级。那么,为什么要使用内存和硬盘,直接扩大 CPU 的存储能力不行吗?这就要提到存储器的 3 个主要的性能指标: 速度 + 容量 + 每位价格。

一般来说,存储器的容量越大则速度越低,速度越高则价格越高。想要获得一个同时满足容量大、速度高且价格低的 “神奇存储器” 是很难实现的。因此,现代计算机系统会采用分层架构,以满足整个系统在容量、速度和价格上最大的性价比。

2.2 存储器的层次结构

在现代计算机系统中,一般采用 “CPU 寄存器 - CPU 高速缓存 - 内存 - 硬盘” 四级存储器结构。自上而下容量逐渐增大,速度逐渐减慢,单位价格也逐渐降低。

存储器金字塔

在此基础上,对各个层级上进行局部优化,就形成了完整的存储器系统:

2.3 为什么在 CPU 和内存之间增加高速缓存?

我认为有 2 个原因:

关于 CPU 三级高速缓存的更多内容,请关注专栏文章。

CPU 三级缓存

2.4 为什么要使用虚拟内存访问内存?

为了满足系统的多进程需求和大内存需求,操作系统在内存这一层级使用了虚拟内存管理。当物理内存资源不足时,操作系统会按照一定的算法将最近不常用的内存换出(Swap Out)到硬盘上,再把要访问数据从硬盘换入(Swap In)到物理内存上。 至于操作系统如何管理虚拟地址和内存地址之间的关系(段式、页式、段页式),对上层应用完全透明。

关于虚拟内存的更多内容,请关注专栏文章。

虚拟内存


3. 存储器类型

这一节,我们来梳理常见的存储器类型。

3.1 按存储材质划分

提示: 由于磁盘和光盘已经逐渐从历史中淡去,以后我们讨论的存储器都默认表示半导体存储器。

3.2 按芯片类型划分

半导体存储器按照存取方式划分可以分为 2 种:

RAM 又分为 SRAM 和 DRAM 两种实现类型:

6 个晶体管组成的 1 比特 SRAM

—— 图片引用自 Wikipedia

1 个晶体管和 1 个电容组成的 1 比特 DRAM

—— 图片引用自 计算机组成原理教程

3.3 为什么内存的访问速度比 CPU 差这么多?

内存的访问速度受制于 DRAM 的性能瓶颈。

在目前的计算机系统中,计算机内存采用的是基于 DRAM (动态随机存取存储器)芯片的存储器,它的基本单元由一个晶体管 + 一个电容组成,在存储密度、功耗和价格等方面表现优秀。但电容会自然放电,需要定时刷新来保证信息不丢失,因此访问速度受损。而高速缓存是基于 SRAM (静态随机存取存储器)芯片的存储器,它的基本单元由 6~8 个晶体管组成。结构更简单,因此访问速度更快,但存储密度不高。


4. 总结

今天,我们简单提到了 CPU 的三级缓存,下一篇文章我们详细展开讨论,敬请期待。


参考资料

上一篇下一篇

猜你喜欢

热点阅读