计算机组成原理-存储器


1. 存储器的定义与作用

存储器是计算机系统中用于存储程序、数据和中间结果的硬件设备,是计算机五大核心部件之一。

  • 核心功能
    • 提供数据的 临时或永久存储 能力。
    • 支持CPU按需快速存取指令和数据,是程序运行的物理基础。

2. 存储器的分类

(1) 按存取方式分类
  • 随机存取存储器(RAM)
    • 可读可写,断电后数据丢失(易失性)。
    • 包括 DRAM(动态RAM,如DDR内存)SRAM(静态RAM,如CPU缓存)
  • 只读存储器(ROM)
    • 通常只读,断电后数据保留(非易失性)。
    • 包括 Mask ROM、PROM、EPROM、EEPROM 及现代 Flash存储器(如SSD)
(2) 按用途分类
  • 主存储器(内存)
    • 直接与CPU交互,存储当前运行的程序和数据(如DRAM)。
  • 辅助存储器(外存)
    • 长期保存数据,速度较慢(如硬盘、SSD、光盘)。
  • 高速缓存(Cache)
    • 位于CPU内部或附近,加速CPU对高频数据的访问(如L1/L2/L3缓存)。
(3) 按存储介质分类
  • 半导体存储器:RAM、ROM、Flash。
  • 磁存储器:硬盘、磁带。
  • 光存储器:CD、DVD、蓝光。

3. 存储器的层次结构

计算机系统采用 多级存储体系,平衡速度、容量与成本:

  1. 寄存器:位于CPU内部,速度最快,容量最小(纳秒级访问)。
  2. 高速缓存(Cache):SRAM实现,容量KBMB级,访问时间110ns。
  3. 主存(内存):DRAM实现,容量GB级,访问时间10~100ns。
  4. 辅存(外存):硬盘/SSD,容量TB级,访问时间ms级。

设计目标:通过层次化设计,使系统整体接近最高层速度,同时拥有最底层容量。


4. 主存储器的组成与工作原理

(1) 主存的基本结构
  • 存储体:由存储单元(如1字节)组成的矩阵,每个单元有唯一地址。
  • 地址寄存器(MAR):存放CPU访问的存储单元地址。
  • 数据寄存器(MDR):暂存从存储单元读取或写入的数据。
  • 读写控制电路:根据CPU命令控制数据的输入/输出。
(2) 读写过程
  • 读操作
    1. CPU将地址送入MAR。
    2. 控制电路选中对应存储单元,数据传入MDR。
    3. CPU从MDR读取数据。
  • 写操作
    1. CPU将地址送入MAR,数据送入MDR。
    2. 控制电路将MDR数据写入对应存储单元。

5. 存储器的性能指标

  • 容量:可存储的二进制位数(如8GB内存)。
  • 存取时间(Access Time):从发出读写命令到完成操作的时间。
  • 存取周期(Cycle Time):连续两次独立存取操作的最小间隔时间(存取时间+恢复时间)。
  • 带宽(Bandwidth):单位时间传输的数据量(如DDR4-3200带宽25.6GB/s)。
  • 功耗:动态功耗(读写时)与静态功耗(待机时)。

6. 高速缓存(Cache)的工作原理

(1) 缓存的作用

利用 局部性原理(时间局部性+空间局部性),将CPU近期可能访问的数据从主存复制到缓存,减少访问主存次数。

(2) 缓存映射方式
  • 直接映射:主存块固定映射到缓存的某一位置,冲突率高但实现简单。
  • 全相联映射:主存块可映射到缓存任意位置,冲突率低但查找复杂。
  • 组相联映射:缓存分组,主存块映射到特定组内的任意行(如4路组相联)。
(3) 替换算法
  • 先进先出(FIFO):替换最早进入的块。
  • 最近最少使用(LRU):替换最久未被访问的块。
  • 随机替换(Random):随机选择替换目标。

7. 辅助存储器的典型技术

  • 机械硬盘(HDD)
    • 通过磁头在旋转磁盘上读写数据。
    • 容量大、成本低,但速度慢(寻道时间+旋转延迟)。
  • 固态硬盘(SSD)
    • 基于NAND Flash芯片,无机械部件,速度快、抗震动。
    • 寿命受限于擦写次数(P/E Cycle),需磨损均衡算法。
  • 光盘
    • 利用激光读写(如CD-ROM、DVD-RW),适合长期存档。

8. 新型存储器技术

  • 3D NAND Flash:通过堆叠存储单元提升容量(如176层堆叠技术)。
  • 相变存储器(PCM):利用材料相变特性实现高速非易失存储。
  • 磁性存储器(MRAM):结合磁阻效应,兼具高速与非易失性。
  • 存算一体(In-Memory Computing):在存储器内部直接完成计算,减少数据搬运。

9. 存储器的应用场景

  • 内存数据库(如Redis):依赖大容量DRAM加速数据查询。
  • AI训练:GPU显存(如HBM2)提供高带宽支持大规模矩阵运算。
  • 嵌入式系统:NOR Flash存储启动代码,SRAM作运行内存。
  • 数据中心:NVMe SSD加速云存储,磁带库用于冷数据备份。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/76769.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

单片机领域中哈希表

以下是单片机领域中哈希表的实际应用及编程实例: 1.哈希表在单片机中的实际应用场景 • 命令解析:在单片机通信中,经常需要解析接收到的命令。使用哈希表可以快速地将命令字符串映射到对应的处理函数,提高命令解析的效率。 • 数…

算法思想之位运算(一)

欢迎拜访:雾里看山-CSDN博客 本篇主题:算法思想之位运算(一) 发布时间:2025.4.12 隶属专栏:算法 目录 滑动窗口算法介绍六大基础位运算符常用模板总结 例题位1的个数题目链接题目描述算法思路代码实现 比特位计数题目链接题目描述…

封装Tcp Socket

封装Tcp Socket 0. 前言1. Socket.hpp2. 简单的使用介绍 0. 前言 本文中用到的Log.hpp在笔者的历史文章中都有涉及,这里就不再粘贴源码了,学习地址如下:https://blog.csdn.net/weixin_73870552/article/details/145434855?spm1001.2014.3001…

全星APQP软件:为用户提供高效、合规、便捷的研发管理体验

全星APQP软件:为用户提供高效、合规、便捷的研发管理体验 为什么选择全星APQP软件系统? 在汽车及高端制造行业,研发项目管理涉及APQP(先期产品质量策划)、FMEA(失效模式与影响分析)、CP&#x…

CTF--网站被黑

一、原题: (1)提示:网站被黑了 黑客会不会留下后门 (2)原网页: 二、步骤: 1.在终端扫描网址: 2.扫描后发现:shell.php 3.输入网址:http://117.…

入门到精通,C语言十大经典程序

以下是十个经典的C语言程序示例&#xff0c;这些程序涵盖了从基础到稍复杂的应用场景&#xff0c;适合初学者和有一定基础的开发者学习和参考。 1. Hello, World! 这是每个初学者学习编程时的第一个程序&#xff0c;用于验证开发环境是否正确配置。 #include <stdio.h>…

神经网络入门—自定义神经网络续集

修改网络 神经网络入门—自定义网络-CSDN博客 修改数据集&#xff0c;yx^2 # 生成一些示例数据 x_train torch.tensor([[1.0], [2.0], [3.0], [4.0]], dtypetorch.float32) y_train torch.tensor([[1.0], [4.0], [9.0], [16.0]], dtypetorch.float32) 将预测代码改为&…

【browser-use+deepseek】实现简单的web-ui自动化

browser-use Web-UI 一、browser-use是什么 Browser Use 是一款开源Python库&#xff0c;专为大语言模型设计的智能浏览器工具&#xff0c;目的是让 AI 能够像人类一样自然地浏览和操作网页。它支持多标签页管理、视觉识别、内容提取&#xff0c;并能记录和重复执行特定动作。…

Vue--常用组件解析

绑定事件v-on和按键修饰符 v-on:click 表示在button元素上监听click事件 简写&#xff1a;click enter space tab 按键修饰符 keyup是用户松开按键才触发 keydown是在用户按下按键时立即触发 代码展示&#xff1a; <!DOCTYPE html><html lang"en" xml…

《JVM考古现场(十八):造化玉碟·用字节码重写因果律的九种方法》

"鸿蒙初判&#xff01;当前因果链突破十一维屏障——全体码农修士注意&#xff0c;《JVM考古现场&#xff08;十八&#xff09;》即将渡劫飞升&#xff01;" 目录 上卷阴阳交缠 第一章&#xff1a;混沌初开——JVM因果律的量子纠缠 第二章&#xff1a;诛仙剑阵改—…

前端vue 项目px转为rem的自适应解决方案

postcss-pxtorem&#xff08;或是postcss-px2rem&#xff09; npm install postcss-pxtorem amfe-flexible --save-dev 在入口文件 main.js 中引入 amfe-flexible&#xff08;响应式适配&#xff09;&#xff1a; main.js import amfe-flexible // 自动设置 html 的 font-s…

基于时间序列分解与XGBoost的交通通行时间预测方法解析

一、问题背景与数据概览 在城市交通管理系统中,准确预测道路通行时间对于智能交通调度和路径规划具有重要意义。本文基于真实道路传感器数据,构建了一个结合时间序列分解与机器学习模型的预测框架。数据源包含三个核心部分: 道路通行数据(new_gy_contest_traveltime_train…

Day14:关于MySQL的索引——创、查、删

前言&#xff1a;先创建一个练习的数据库和数据 1.创建数据库并创建数据表的基本结构 -- 创建练习数据库 CREATE DATABASE index_practice; USE index_practice;-- 创建基础表&#xff08;包含CREATE TABLE时创建索引&#xff09; CREATE TABLE products (id INT PRIMARY KEY…

【C++】继承:万字总结

&#x1f4dd;前言&#xff1a; 这篇文章我们来讲讲面向对象三大特性之一——继承 &#x1f3ac;个人简介&#xff1a;努力学习ing &#x1f4cb;个人专栏&#xff1a;C学习笔记 &#x1f380;CSDN主页 愚润求学 &#x1f304;其他专栏&#xff1a;C语言入门基础&#xff0c;py…

Java 架构设计:从单体架构到微服务的转型之路

Java 架构设计&#xff1a;从单体架构到微服务的转型之路 在现代软件开发中&#xff0c;架构设计的选择对系统的可扩展性、可维护性和性能有着深远的影响。随着业务需求的日益复杂和用户规模的不断增长&#xff0c;传统的单体架构逐渐暴露出其局限性&#xff0c;而微服务架构作…

Django3 - 开启Django Hello World

一、开启Django Hello World 要学习Django首先需要了解Django的操作指令&#xff0c;了解了每个指令的作用&#xff0c;才能在MyDjango项目里编写Hello World网页&#xff0c;然后通过该网页我们可以简单了解Django的开发过程。 1.1 Django的操作指令 无论是创建项目还是创建项…

2025阿里云AI 应用-AI Agent 开发新范式-MCP最佳实践-78页.pptx

2025阿里云AI 应用-AI Agent 开发新范式-MCP最佳实践&#xff0c;包含以下内容&#xff1a; 1、AI 应用架构新范式 2、云原生API网关介绍 3、云原生API网关底座核心优势 4、流量网关最佳实践 5、AI 网关代理 LLM 最佳实践 6、MCP网关最佳实践 7、MSE Nacos MCP Server 注册中心…

Pytorch深度学习框架60天进阶学习计划 - 第41天:生成对抗网络进阶(一)

Pytorch深度学习框架60天进阶学习计划 - 第41天&#xff1a;生成对抗网络进阶&#xff08;一&#xff09; 今天我们将深入探讨生成对抗网络(GAN)的进阶内容&#xff0c;特别是Wasserstein GAN&#xff08;WGAN&#xff09;的梯度惩罚机制&#xff0c;以及条件生成与无监督生成…

大模型到底是怎么产生的?一文了解大模型诞生全过程

前言 大模型到底是怎么产生的呢? 本文将从最基础的概念开始,逐步深入,用通俗易懂的语言为大家揭开大模型的神秘面纱。 大家好,我是大 F,深耕AI算法十余年,互联网大厂核心技术岗。 知行合一,不写水文,喜欢可关注,分享AI算法干货、技术心得。 【专栏介绍】: 欢迎关注《…

五子棋(测试报告)

文章目录 一、项目介绍二、测试用例三、自动化测试用例的部分展示注册登录游戏大厅游戏匹配 总结 一、项目介绍 本项目是一款基于Spring、SpringMVC、MyBatis、WebSocket的双人实时对战五子棋游戏,游戏操作便捷&#xff0c;功能清晰明了。 二、测试用例 三、自动化测试用例的…