当前位置: 首页 > news >正文

【计算机组成原理】LRU计数器问题

学习最近最久未使用(LRU)算法的时候是否会有这样一个疑问,为什么命中某一行时,该行的计数器清零,比其低的计数器加1,其余不变。

先来回顾一下计数器变化的规则

①命中时,所命中的行的计数器清零,比其低的计数器加1,其余不变;

②未命中且还有空闲行时,新装入的行的计数器置为0,其余非空闲行计数器全加1;

③未命中且没有空闲行时,计数器值最大的行被替换,新装入的行的计数器置为0,其余全加1;

以4路组相联为例说明,4路组相联,即4个cache行为一组,那么为了表示其先后未访问时间的排名,需要在cache行里面添加冗余位,4个cache行只需两个冗余位就能表示其排名,0、1、2、3

假设第一行计数器是2,第二行计数器是3,第三行计数器是1,第四行计数器是0

计数器cache行
21
32
13
04

如果规则①是所命中的行的计数器清零,其余所有计数器加1的话,而再次访问到第一行时,计数器就会变成

计数器cache行
01
42
23
14

这样计数器最高就变成了4,用二进制表示的话是100,原本2个二进制位将无法表示

而且,LRU的计数器本质上并不是记录的未命中次数,就拿班级考试来说,如果小明原本是第二名,一天小明转班走了,第三名变成了第二名,第四名变成了第三名…………

当然这个例子并不太恰当,只是可能会比较形象。

http://www.dtcms.com/a/358437.html

相关文章:

  • Vue3 + GeoScene 地图点击事件系统设计
  • Selenium + PO 框架进阶实践:接入 Allure 报告与 Jenkins 持续集成
  • macOs上ffmpeg带入libx264库交叉编译
  • docker 启动一个clickhouse , docker 创建ck数据库
  • Python远程文件管理移动端适配与跨平台优化实战
  • vue3多个el-checkbox勾选框设置必选一个
  • 【OpenGL ES】光栅化插值原理和射线拾取原理
  • Day17(前端:JavaScript基础阶段)
  • Cocos游戏中自定义按钮组件(BtnEventComponent)的详细分析与实现
  • HAProxy 负载均衡全解析:从基础部署、负载策略到会话保持及性能优化指南
  • Spring : 事务管理
  • 音视频学习(六十一):H265中的VPS
  • Prompt Engineering:高效构建智能文本生成的策略与实践
  • 深层语义在自然语言处理中的理论框架与技术融合研究
  • AI大模型:(二)5.2 文生视频(Text-to-Video)模型训练实践
  • FPGA增量式方差与均值计算
  • 响应式编程框架Reactor【4】
  • FPGA学习笔记——SPI读写FLASH
  • 优化器全指南:从原理到调优实战
  • 原子操作与锁实现
  • 由于不对称GND过孔配置,差分信号过孔上的差模到共模转换
  • SQL相关知识 CTF SQL注入做题方法总结
  • seafile-setup-troubleshooting_# Seafile 安装与问题解决记录 # Seafile/Seahub 启动问题记录文档
  • Scikit-learn Python机器学习 - Scikit-learn加载数据集
  • C/C++:AddressSanitizer内存检测工具
  • 《以奋斗者为本》读书笔记(上篇:价值管理)
  • Ethan开发者创新项目日报 | 2025-08-30
  • MySQL之事务
  • 渲染数据列表:`map` 方法与 `key` 的奥秘
  • Rust 泛型:抽象与性能的完美融合(零成本抽象的终极指南)