计算机存储体系

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

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(缓冲池)就是内存中的一块区域,它模拟了计算机的存储体系,将热数据放在内存中,冷数据放在磁盘上。

相关推荐
行乾16 小时前
鸿蒙端 IMSDK 架构探索
架构·harmonyos
石小石Orz16 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
若风的雨17 小时前
【deepseek】RISC-V 的CSR寄存器详解
架构
ZHENGZJM18 小时前
架构总览:Monorepo 结构与容器化部署
架构·go·react·全栈开发
搜佛说19 小时前
比SQLite更快,比InfluxDB更轻:sfsDb的降维打击
jvm·数据库·物联网·架构·sqlite·边缘计算·iot
提子拌饭13319 小时前
昼夜节律下的肝脏代谢清除率演算仪:基于鸿蒙Flutter的双路流场与酶解粒子对照架构
flutter·华为·架构·harmonyos·鸿蒙
SuperEugene19 小时前
前端通用基础组件设计:按钮/输入框/弹窗,统一设计标准|组件化设计基础篇
前端·javascript·vue.js·架构
贺小涛20 小时前
DeepSeek vs ChatGPT:技术架构深度解析与核心优势对比
chatgpt·架构
Ghost Face...20 小时前
Linux USB 全栈解析:OTG + Type-C + PD 内核架构(架构师级)
linux·c语言·架构
be to FPGAer20 小时前
架构与微架构设计
架构