- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
存储系统的设计正是局部性原理的体现。
计算机组成原理第四章 知识点一:存储系统层次结构和评价方法 主讲教师:吴非 问题引入 数据和指令存在哪里?计算机里为什么使用存储系统?如何评价其性能? 学习建议 ?系统观:与指令系统的设计以及优化建立联系,程序局部性原理是程序优化的指南,存储系统的设计正是局部性原理的体现。 ?构造观:通过存储系统的设计思想,分析存储层次体系架构,理解程序局部性原理,掌握存储性能评价方法。 1. 存储器分类 存储介质 半导体(MOS、TTL,易失) 磁性(非易失)、光盘(激光、非易失) 存储方式(存储时间与物理地址的关系) 随机:无关(随机存储器,只读存储器) 串行:有关(顺序存储器,直接存储器) 存储功能和速度 寄存器,主存储器、高速缓冲存储器、辅助存储器 (外存储器) 2.存储系统的层次结构 磁带、光盘 磁盘 Cache(SRAM) 主存(DRAM) CPU寄存器 存储速度 访问频率 单位成本 存储容量 外存/辅存 内存 存储器的目标: 大容量、高速度、低价格 2.存储系统的层次结构 三级存储架构:高速缓存,主存储器,辅存存储器 目标:主存储器为核心,缓存(cache)速度,辅存容量 CPU 寄存器 高速缓存 主存 磁盘高速缓存 硬盘 磁带、光盘、网络存储 辅助存储系统 主存:存储当前使用的程序和数据 辅存:后备程序和数据 高速缓存:存储当前经常使用的数据和程序 3.分层结构的理论基础:程序局部性原理 存储的内容:数据,指令 数据: 数组, 结构体, 变量, 指针 指令:顺序访问的指令, 循环体, 子函数 程序局部性:程序仅访问内存很小一部分空间 空间局部性: 如果内存某个区域刚刚被访问,不久的将来其相邻区域很有可能被访问 (顺序指令, 数组) 时间局部性:如果内存某个区域刚刚被访问,不久的将来该区域可能会被重复访问(循环, 局部变量) 例:假定数组元素在主存按行优先顺序顺序存放。试改变下列函数中循环的顺序,使得其数组元素的访问与排列顺序一致,并说明为什么修改后的程序比原来的程序执行时间短。 int sum_array ( int a[N][N]) { int i, j, sum=0; for (i=0; i N; i++) for (j=0; j N; j++) sum+=a[j][i]; return sum; } int sum_array ( int a[N][N]) { int i, j, sum=0; for (i=0; i N; i++) for (j=0; j N; j++) sum+=a[i][j]; return sum; } 修改后程序的数组元素的访问与排列顺序一致,使得空间局部性比原程序好,故执行时间更短。 修改前: 修改后: 4.存储器主要技术指标 存储容量 存储器所能存储的二进制信息的位数 存储速度 存储时间:存储器访问时间, 读出时间或写入时间 存储周期:连续两次访问存储器所需要的最小时间间隔 存储器带宽:单位时间内存储器存取的信息量 存储器的可靠性 知识点一 回顾 存储器的种类 存储层次结构和组织方式 程序局部性原理 存储器性能评价方法
文档评论(0)