当前位置: 网站首页 >> 知识库 >> 硬件漫谈 >> 正文
【计算机组成原理】存储系统(四)—— 高速缓冲存储器 Cache
发布时间:2024-04-02       编辑:网络中心       浏览次数:

采用双端口RAM多模块存储器提高存储器的工作速度,优化后速度与CPU差距依然很大。这时提出了 主存-Cache 的方式。

一、Cache的工作原理

基于局部性原理,把程序中正在使用的部分存放在一个高速的、容量教小的 Cache 中,使 CPU 的访存操作大多数针对 Cache 进行,从而大大提高程序的执行速度。

  • 局部性原理

空间局部性:在最近的未来要用到的信息(指令和数据),很可能与现在正在使用的信息在存储空间上是邻近的。Eg:数组元素、顺序执行的指令代码。

时间局部性:在最近的未来要用到的信息,很可能是现在正在使用的信息。Eg:循环结构的指令代码。

在这里插入图片描述

性能分析

设 t c t_ctc 为访问一次Cache 所需时间,t m t_mtm 为访问一次主存所需时间。

  • 命中率 H:CPU 欲访问的信息已在Cache中的比率

  • 缺失(未命中)率:M = 1 - H

  • Cache —主存 系统的平均访问时间 t 为

先访问Cache,若Cache未命中再访问主存:

t = H ∗ t c + ( 1 − H ) ∗ ( t c + t m ) t=H*t_c + (1-H)*(t_c + t_m)t=Htc+(1H)(tc+tm)

同时访问 Cache 和主存,若 Cache 命中则立即停止访问主存:

t = H ∗ t c + ( 1 − H ) ∗ t m t=H*t_c + (1-H)* t_mt=Htc+(1H)tm

  • 例题

在这里插入图片描述

二、使用 Cache 所必须解决的问题

  • 如何区分 Cache 与 主存 的数据块对应关系? ——Cache和主存的映射方式

  • Cache 很小,主存很大。如果Cache满了怎么办? ——替换算法

  • CPU修改了Cache中的数据副本,如何确保主存中数据母本的一致性? ——Cache写策略

关于 Cache和主存的映射方式、Cache替换算法、Cache写策略的详细内容,见下面链接文章:

在这里插入图片描述

链接:https://blog.csdn.net/weixin_43848614/article/details/126822309

作者:何为xl

关闭本页

澳门人威尼斯3966教育技术与网络中心版权所有

©GDAFC Education Technology & Network Center, All Rights Reserved.