计算机组成原理——3.2多级存储结构

一、层次结构

主存容量小但不是特别小,例如4GB。CPU访问时速度快,但没有特别快,例如64bit/s。价格贵,但不是特别贵。所以需要需要一些东西配合主存。于是有了外存和Cache。

外存,例如硬盘,容量很大,例如256GB,价格便宜。但是速度很慢,例如5bit/s

Cache,容量很小,例如1GB,价格很高。但速度很快,例如128bit/s。

所以形成两种层次,Cache-主存层次和主存-外存层次。前者解决CPU与主存速度不匹配问题,后者解决主存容量问题。

二、交换信息

外存把信息给主存,主存把信息给Cache,Cache的信息被CPU访问。

当然,CPU也可以访问主存,因为Cache的容量比较小,主存只能把一部分数据给Cache,当CPU在Cache读取不到数据时,就会直接去主存里找。如果CPU在Cache读取到数据,称为Cache命中,否则称为缺失或者不命中。

CPU访问不到外存,只能是外存把数据给主存,再被CPU访问。

三、例题

1.计算机采用分级方式是为了()

A.方便编程

B.解决容量,速度,价格三者矛盾

C.保存大量数据方便

D.操作方便

答案:B

2.存储器速度从快到慢依次是()

A.寄存器,主存,Cache,外存

B.寄存器,主存,外存,Cache

C.寄存器,Cache,外存,主存

D.寄存器,Cache,主存,外存

答案:D

解析:CPU永远速度最快,寄存器在CPU中,可以直接读取寄存器内容,所以寄存器最快。

相关推荐
袁雅倩19973 小时前
当吸尘器、筋膜枪都用上Type-C,供电方案该怎么选?浅谈PD取电芯片ECP5702的应用
c语言·开发语言·支持向量机·动态规划·推荐算法·最小二乘法·图搜索算法
CHANG_THE_WORLD8 小时前
C语言中的 %*s 和 %.*s 和C++的字符串格式化输出
c语言·c++·c#
消失的旧时光-19438 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
2501_931803759 小时前
Go:一门为解决C语言痛点而生的现代语言
c语言·开发语言·golang
qeen879 小时前
【数据结构】二叉树相关经典函数C语言实现
c语言·数据结构·c++·笔记·学习·算法·二叉树
Hello.Reader11 小时前
ds4.c 深度解析为 DeepSeek V4 Flash 打造的本地推理引擎
c语言·开发语言
谙弆悕博士13 小时前
快速学C语言—— 第0章:C语言简介
c语言·开发语言·经验分享·笔记·程序人生·课程设计·学习方法
谙弆悕博士15 小时前
Lua学习笔记
c语言·开发语言·笔记·学习·lua·创业创新·业界资讯
qq38624619615 小时前
C语言中将数字转换为字符串的方法
c语言·格式化输出·字符串转换·sprintf·snprintf
LuminousCPP15 小时前
C 语言动态内存管理全解析:从基础函数到柔性数组与内存分区
c语言·经验分享·笔记·学习·柔性数组