计算机组成原理——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中,可以直接读取寄存器内容,所以寄存器最快。

相关推荐
hipolymers9 分钟前
C语言怎么样?难学吗?
c语言·数据结构·学习·算法·编程
努力努力再努力wz3 小时前
【Linux网络系列】深入理解 I/O 多路复用:从 select 痛点到 poll 高并发服务器落地,基于 Poll、智能指针与非阻塞 I/O与线程池手写一个高性能 HTTP 服务器!(附源码)
java·linux·运维·服务器·c语言·c++·python
minji...3 小时前
Linux 线程同步与互斥(四) POSIX信号量,基于环形队列的生产者消费者模型
linux·运维·服务器·c语言·开发语言·c++
uElY ITER3 小时前
VS与SQL Sever(C语言操作数据库)
c语言·数据库·sql
程序猿编码4 小时前
给Linux程序穿“隐身衣”——ELF运行时加密器全解析(C/C++代码实现)
linux·c语言·c++·网络安全·elf·内存安全
Goway_Hui4 小时前
【ReactNative鸿蒙化-三方库使用与C-API集成】
c语言·react native·harmonyos
♛识尔如昼♛5 小时前
C 基础(14) - 结构和其他数据形式
c语言·结构体
syker6 小时前
AIFerric v2.0 项目总结报告
c语言·开发语言·c++
念恒123066 小时前
进程--进程状态(上)
linux·c语言
小糯米6017 小时前
C语言指针3
c语言·数据结构·算法