CMU CSAPP笔记 第六章

memory hierarchy(csapp-6.1,6.2,6.3)

  • 机械硬盘的构造
    这里写图片描述

  • 当程序读写文件时,我们的操作系统并不会真正同步地去操作硬盘,而是把硬盘读写请求先在内存中 hold 上一小会儿(几十毫秒),然后,对这些读写请求做 mergesort

    • merge 是把相同的操作合并,相同的读操作只读一次,相同的写操作,只写最后一次
    • sort 是把不同的操作排个序,这样可以让硬盘向一个方向转一次就可以把所有的数据读出来,而不是来来回回地转。这样可以极大地提高硬盘的吞吐率
    • 对于机械硬盘才有merge和sort,固态盘一般只merge不sort
  • 总线
    这里写图片描述

  • 局部性原理(locality)

    • 通过局部性原理可以设计高速缓存
    • 时间局部性(Temporal Locality): 如果一个信息项正在被访问,那么在近期它很可能还会被再次访问。程序循环、堆栈等是产生时间局部性的原因。
    • 空间局部性(Spatial Locality): 在最近的将来将用到的信息很可能与现在正在使用的信息在空间地址上是临近的
    • 顺序局部性(Order Locality): 在典型程序中,除转移类指令外,大部分指令是顺序进行的。顺序执行和非顺序执行的比例大致是5:1。此外,对大型数组访问也是顺序的。指令的顺序执行、数组的连续存放等是产生顺序局部性的原因。
  • 储存体系
    这里写图片描述

cache memories(csapp-6.4)

  • 高速缓存(cache)
    • SRAM内存
    • 如果一个系统的内存地址有m位,那么会形成M = 2^m个地址
      • 高速缓存会被组织成S=2^s个set,每个set里有E个block,每个block大小为B
        • 所以容量C = S * E * B
      • 每个block中有一个位判断是否有效,t个位为标记位(是内存地址位的子集)
        • t = m - s - b
          这里写图片描述
  • 组索引
    • 一般采用地址的中部,因为对于连续的地址(例如数组),地址的开头大多相同,高速缓存会频繁冲突不命中
    • 组索引的位数由cache中有多少组决定
  • 块偏移
    • 当一个块没有命中时,不仅会读取请求内存地址的数据,还会同时读取旁边的数据,直到填满cache的块,因此而实现了空间局部性
    • 快的大小一般大于多个地址中数据的大小,从而可以利用空间局部性
    • 但是块太大会导致给定大小的cache行数减少,同时对于不命中的处罚会增加
      这里写图片描述
  • 储存器山
    这里写图片描述

编写cache友好的代码(CSAPP-6.6,6.7)

  • 通过减少cache miss来提高矩阵相乘速度
    这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

  • 解决方法:分组
    这里写图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CMU CSAPP(Carnegie Mellon University Computer Systems: A Programmer's Perspective)是一门著名的计算机系统课程,其幻灯片是课程的主要教学工具之一。CMU CSAPP幻灯片通过清晰简洁的叙述、图表和示例代码等方式,帮助学生理解和掌握计算机系统的基本概念和原理。 CMU CSAPP幻灯片内容全面,包括计算机系统的各个层次,如操作系统、处理器体系结构、存储器层次结构等。对于每个主题,幻灯片提供了扎实的理论基础和实际应用案例,帮助学生深入理解计算机系统的运作原理。 CMU CSAPP幻灯片从浅入深地介绍计算机系统,并使用生动的案例和图表解释抽象的概念,使得学生能够迅速理解和掌握重要的知识点。幻灯片还提供了丰富的练习题和编程实践,帮助学生巩固所学内容,并将理论知识与实践相结合。 CMU CSAPP幻灯片的组织结构严谨,从基础概念到高级主题有序地展开,逐步增加学生的难度和挑战。这种递进的教学方法有助于学生逐步建立起对计算机系统的全面认识,并培养他们独立分析和解决问题的能力。 总之,CMU CSAPP幻灯片是一种有效的教学工具,通过清晰简洁的展示和理论与实践相结合的方式,帮助学生深入理解和掌握计算机系统的原理和应用。它为学生提供了丰富的知识和实践经验,为未来的计算机科学和工程领域的发展打下坚实的基础。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值