计算机存储体系

计算机存储体系是一个金字塔结构 ,它按照速度、容量、成本进行分级,目的是用最低的成本实现最快的平均访问速度。

1. 核心逻辑:局部性原理

计算机程序通常遵循局部性原理

  • 时间局部性:刚被访问的数据很可能再次被访问。

  • 空间局部性:访问某个数据时,其附近的数据也很可能被访问。

基于这个原理,系统将最热的数据 放在最快但最贵 的存储中,将冷数据 放在最慢但最便宜的存储中。

2. 存储金字塔(从快到慢)

下图清晰地展示了计算机存储体系的层级结构:

3. 各层级详细对比

层级 典型容量 访问速度 成本 物理位置 用途
寄存器 ~1KB 0.3 ns 极高 CPU内部 存放当前指令和操作数
L1缓存 32-512 KB 0.5-1 ns 极高 CPU内部 存放最热指令和数据
L2缓存 256K-4 MB 3-10 ns CPU内部/外部 存放次热数据
L3缓存 8-64 MB 10-20 ns 中高 CPU外部 共享缓存,减少内存访问
主内存 8-256 GB 50-100 ns 中等 内存条 运行程序和临时数据
SSD 256 GB-4 TB 50-150 μs 硬盘位 持久化存储,系统盘
HDD 1-20 TB 1-10 ms 极低 硬盘位 大容量冷数据存储
网络/磁带 无限 10-100 ms 极低 远程/离线 备份、归档

4. 关键概念解析

缓存(Cache)
  • 定义:位于CPU和主内存之间的高速缓冲存储器(L1/L2/L3)。

  • 作用 :解决CPU和内存之间的速度鸿沟。CPU速度极快,而内存相对较慢,缓存通过预测和预取数据,让CPU"感觉"内存很快。

  • 命中率 :如果CPU要的数据在缓存中,称为命中 ;否则需要去内存取,称为未命中。现代CPU的缓存命中率通常在90%以上。

内存(RAM)
  • 特性易失性(断电数据丢失)。

  • 作用:存放当前正在运行的程序和数据。它是CPU的"工作台"。

外存(硬盘)
  • 特性非易失性(断电数据不丢失)。

  • 作用:长期保存数据。当内存不够用时,操作系统会将不常用的内存数据"交换"到硬盘(虚拟内存机制)。

5. 性能优化启示

  • 写代码时要考虑缓存友好性:尽量让数据连续访问(空间局部性),避免在内存中"跳来跳去",这样可以提高缓存命中率,大幅提升程序速度。

  • 数据库设计:数据库的Buffer Pool(缓冲池)就是内存中的一块区域,它模拟了计算机的存储体系,将热数据放在内存中,冷数据放在磁盘上。

相关推荐
春天花会开1312 小时前
Kubernetes 高可用架构实战指南
架构
码云之上2 小时前
万星入坞·其三:SDK 轻量组件如何优雅地"点亮"
性能优化·架构·前端框架
枫叶林FYL2 小时前
【强化学习】3 双系统持续强化学习:快速迁移与元知识整合架构手册
人工智能·机器学习·架构
AI科技星2 小时前
哥德巴赫猜想1+1基于平行素数对等腰梯形网格拓扑与素数渐近密度的大偶数满填充完备性证明
人工智能·线性代数·架构·概率论·学习方法
小短腿的代码世界3 小时前
信号路由风暴:Qt算法交易系统的高频信号分发架构
qt·算法·架构
2301_780789663 小时前
手游遇到攻击为什么要用SDK游戏盾手游遇到攻击为什么要用 SDK 游戏盾?
安全·web安全·游戏·架构·kubernetes·ddos
中小企业实战军师刘孙亮4 小时前
小微企业生存发展指南:从求稳到扩张的实战策略-佛山鼎策创局破局增长咨询
架构·产品运营·音视频·制造·业界资讯
sanduo1125 小时前
什么是优秀的部署架构?
架构
国科安芯5 小时前
ASP7A84AS与主流架构兼容替代及系统级电源完整性解决方案的深度研究
单片机·嵌入式硬件·架构
JZC_xiaozhong5 小时前
研发体系集成架构:打通OA与PLM的核心参考
大数据·架构·流程自动化·数据集成与应用集成