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

25考研计算机组成原理复习·3.5高速缓冲存储器

高速缓冲存储器Cache

  1. 工作原理:将某些主存块复制到Cache中,缓和CPU与主存之间的速度矛盾
  2. 局部性原理
    1. 时间局部性:现在访问的地址,不久之后也很可能被再次访问
    2. 空间局部性:现在访问的地址,其附近的地址也很可能即将被访问
  3. 性能分析
    1. 命中率H:CPU欲访问的信息已在Cache中的比率
    2. 缺失(未命中)率:M = 1 - H
    3. 👩‍💻 两种方式
      1. 先访问Cache,发现未命中再访问主存
      2. 同时访问Cache和主存,若Cache命中则停止访问主存
  4. 其他概念
    1. 主存与Cache之间以“块”为单位进行数据交换
    2. 主存的“块”又叫“页/页框/页面”;Cache的“块”又叫“行”
    3. 主存地址可拆分为(主存块号,块内地址)的形式

 每次被访问的主存块,一定会被立即调入Cache

Cache-主存映射方式

Cache中存储的信息

  1. 有效位(0/1)+ 标记 + 整块数据
  2. 其中“标记”用于指明对应的内存块,不同映射方式,“标记”的位数不同

全相联映射

  1. 主存块可以放到Cache的任意位置
  2. 主存地址结构:标记(整个主存块号)+ 块内地址
  3. 优点:Cache存储空间利用充分,命中率高;缺点:查找“标记”最慢,有可能需要对比所有行的标记

直接映射

  1. 主存块只能放到特定的某个Cache行,行号 = 主存块号 % 总行数
  2. 主存地址结构:标记(主存块号前几位)+ 行号(主存块号末几位)块内地址
  3. 优点:对于任意一个地址,只需对比一个“标记”,速度最快;缺点:Cache存储空间利用不充分,命中率低

组相联映射

  1. 主存块可以放到特定分组中的任意位置,所属组号 = 主存块号 % 总组数
  2. 主存地质结构:标记(主存块号前几位)+ 组号(主存块号末几位)块内地址
  3. 优点:另外两种方式折中,综合效果较好
  4. 术语:n路组相联映射——每n各Cache行为一组

Cache替换算法

  1. 随机算法(RAND)
    1. 随便选一个主存块替换
    2. 过于Freestyle,效果很差
  2. 先进先出算法(FIFO)
    1. 优先替换最先被调入Cache的主存块
    2. 不遵循局部性原理,效果差
  3. 👩‍💻 近期最少使用(LRU)
    1. 将最久没有被访问过的主存块替换。每个Cache行设置一个“计数器”(Cache块的总数=2^n,则计数器只需n位),用于记录多久没有被访问
    2. 基于“局部性原理”,近期被访问过的主存块,在不久的将来也很有可能被再次访问,因此淘汰最久没被访问过的块是合理的。LRU算法的实际运行效果优秀,Cache命中率高。
  4. 最不经常使用(LFU)
    1. 将被访问次数最少的主存块替换。每个Cache行设置一个“计数器”,用于记录被访问过多少次
    2. 曾经被经常访问的主存块在未来不一定会用到,LFU实际运行效果不好

Cache写策略

非写分配法通常与全写法合用,写分配法通常和回写法合用

  1. 写命中
    1. 全写法(直写法,write-through):当CPU对Cache写命中时,必须把数据同时写入Cache和主存,一般使用写缓冲(write buffer)
    2. 回写法(write-back):当CPU对Cache写命中时,只修改Cache的内容,而不立即写入主存,只有当此块被换出时才写回主存
  2. 写不命中
    1. 写分配法(write-allocate):当CPU对Cache写不命中时,把主存中的块调入Cache,在Cache中修改。
    2. 非写分配法(not-write-allocate):当CPU对Cache写不命中时只写入主存,不调入Cache
  3. 多级Cache:现代计算机通常采用多级Cache结构,各级Cache间常采用“全写法+非写分配法”,Cache和主存间常采用“写回法+写分配法”

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • bootchart抓Android系统启动各阶段性能数据
  • 【微服务】Spring Cloud Alibaba 的介绍以及和主要功能
  • Type-C接口主要的几个功能引脚及功能
  • 【题目/训练】:双指针
  • 云主机部署 TiDB 测试集群
  • 景联文科技:一文详解如何构建高质量SFT数据
  • java基础03——Arrays.asList与ArrayList的区别(基本概念、用法、使用场景)
  • 24/8/17算法笔记 模仿学习算法
  • Spring中AbstractAutowireCapableBeanFactory
  • Unity3D开发之OnCollisionXXX触发条件
  • Spring Boot集成Devtools实现热更新?
  • 8.15 day bug
  • 最佳薪酬管理系统盘点:9款优选推荐
  • 微信答题小程序产品研发-后端开发
  • 重复的子字符串 | LeetCode-459 | 字符串匹配 | KMP | 双指针
  • JavaScript-如何实现克隆(clone)函数
  • 【RocksDB】TransactionDB源码分析
  • 2018天猫双11|这就是阿里云!不止有新技术,更有温暖的社会力量
  • Angularjs之国际化
  • CentOS 7 修改主机名
  • create-react-app做的留言板
  • pdf文件如何在线转换为jpg图片
  • spring-boot List转Page
  • 基于 Ueditor 的现代化编辑器 Neditor 1.5.4 发布
  • 免费小说阅读小程序
  • 面试总结JavaScript篇
  • 那些被忽略的 JavaScript 数组方法细节
  • 少走弯路,给Java 1~5 年程序员的建议
  • 项目管理碎碎念系列之一:干系人管理
  • “十年磨一剑”--有赞的HBase平台实践和应用之路 ...
  • ‌‌雅诗兰黛、‌‌兰蔻等美妆大品牌的营销策略是什么?
  • # 透过事物看本质的能力怎么培养?
  • #pragma once与条件编译
  • $Django python中使用redis, django中使用(封装了),redis开启事务(管道)
  • (27)4.8 习题课
  • (二) 初入MySQL 【数据库管理】
  • (附程序)AD采集中的10种经典软件滤波程序优缺点分析
  • (回溯) LeetCode 77. 组合
  • (四)模仿学习-完成后台管理页面查询
  • (五)大数据实战——使用模板虚拟机实现hadoop集群虚拟机克隆及网络相关配置
  • (轉貼) 蒼井そら挑戰筋肉擂台 (Misc)
  • (最全解法)输入一个整数,输出该数二进制表示中1的个数。
  • *上位机的定义
  • .NET 材料检测系统崩溃分析
  • .NET/C# 使用反射注册事件
  • .NET/C#⾯试题汇总系列:集合、异常、泛型、LINQ、委托、EF!(完整版)
  • .Net调用Java编写的WebServices返回值为Null的解决方法(SoapUI工具测试有返回值)
  • .Net面试题4
  • .NET学习教程二——.net基础定义+VS常用设置
  • @data注解_一枚 架构师 也不会用的Lombok注解,相见恨晚
  • [ IO.File ] FileSystemWatcher
  • []利用定点式具实现:文件读取,完成不同进制之间的
  • [BUUCTF]-PWN:wustctf2020_number_game解析(补码,整数漏洞)
  • [BZOJ3757] 苹果树
  • [c]扫雷