存储器三-高速缓冲存储器

在这里插入图片描述

原因

避免CPU空等
在这里插入图片描述
程序局部性原理

  • 时间的局部性(当前正在使用的程序或指令,将来还会用到。放到cache中,提高效率)
  • 空间局部性(当前正在执行的指令,它相邻的指令可能很快就要用到,所以以一个程序块为单位,将主存中的程序块包括它相邻的指令缓存到chache中)

工作原理

在这里插入图片描述
以块为单位,地址相同,大小相同。

  1. 命中与未命中
    命中:主存块调入缓存中
    未命中:主存块未调入缓存中

  2. cache命中率
    CPU欲访问的信息在cache中的比率
    命中率与cache容量块长有关
    一般每块取4-8个字
    块长取一个存取周期内从主存调出的信息长度

  3. cache-主存系统的效率
    效率e与命中率有关

cache基本结构

在这里插入图片描述
将主存地址映射到缓存中定位称为地址映射,将主存地址变换成缓存地址称为地址变换,当新的主存块需要调入缓存中,而它的可用位置又被占用时,需根据替换算法解决调入问题

cache读写操作


在这里插入图片描述

cache与主存一致性

  • 写直达法:既写入缓存又写入主存。(容易多次写操作)
  • 写回法:只写入缓存,当cache数据被替换出去时再写入主存。(允许一段时间缓存和主存不一致,非实时一致),多CPU会有问题,因为每个cpu都会有一个缓存,所以会有多份缓存,产生不一致。

cache改进

  1. 增加cache的级数(现代cpu都有三级缓存包括片内cache,便外cache)
  2. 统一缓存和分立缓存(指令cache 和 数据cache 分开)

cache主存地址映射

主存数据块的地址如何映射到cache中的地址的

  1. 直接映射
  2. 全相联映射
  3. 组相联映射

直接映射
映射到一个指定cache块中、
在这里插入图片描述
每个缓存块可以和多个主存块对应
每个主存块只能喝一个缓存块对应
结构简单、速度快、冲突可能性大、利用率低

全相联映射
在这里插入图片描述
缓存块和主存块多对多的关系,任意存放。
利用率高、遍历所有速度慢

组相联映射
给定块可以放入指定组中。可以放入组中任何位置。
在这里插入图片描述
属于上两个的折中方案:
主存中的区可以放入cache中的指定组中。
相较于直接映射:一个块有多个位置
相较于全相联:查找是否调入,查询指定组即可,不需要和每一个比较。

替换算法

可被放入的cache地址都满了,选择cache块退出,替换新主存块。

  1. 先进先出FIFO
  2. 近期最少使用算法LRU(比较好的体现了局部性原理)

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值