当前位置: 首页 > news >正文

计组之存储系统

存储器概述

分类

1.按在计算机中的作用(层次)分类

  • 主存储器。CPU可以直接随机地对其进行访问,也可以和高速缓冲存储器(Cache)及辅助存储器交换数据。
  • 辅助存储器。辅存的内容需要调入主存后才能被CPU访问。
  • 高速缓冲存储器。位于主存和CPU之间,现代计算机通常将它们制作在CPU中。
别名用途特点
主存储器主存,内存储器(内存)用来存放计算机运行期间所需的程序和数据容量较小、存取速度较快、每位的价格较高。
辅助存储器

辅存,外存储器

(外存)

用来存放当前暂时不用的程序和数据,以及一些需要永久性保存的信息容量大、存取速度较慢、单位成本低。
高速缓冲存储器Cache用来存放当前 CPU经常使用的指令和数据Cache的存取速度可与CPU的速度相匹配,但存储容量小、价格高。

2.按存储介质分类

  • 存储器可分为磁表面存储器(磁盘、磁带)
  • 磁芯存储器
  • 半导体存储器(MOS型存储器、双极型存储器)
  • 光存储器(光盘)。

3.按存取方式分类

  • 随机存储器(RAM)。 RAM又分为静态RAM和动态RAM 
  • 只读存储器(ROM)。 
  • 串行访问存储器。包括:顺序存取存储器(如磁带)与直接存取存储器(如磁盘、光盘)。
  • 顺序存取存储器 的内容只能按某种顺序存取,存取时间的长短与信息在存储体上的物理位置有关,其特点是存取速度慢。
  • 直接存取存储器 既不像RAM那样随机地访问任何一个存储单元,又不像顺序存取存储器那样完全按顺序存取,而是介于两者之间。存取信息时通常先寻找整个存储器中的某个小区域(如磁盘.上的磁道),再在小区域内顺序查找。
特点
随机存储器(RAM)随机存取,而且存取时间与存储单元的物理位置无关读写方便、使用灵活,主要用作主存或高速缓冲存储器
只读存储器(ROM)只能随机读出而不能写入,信息一旦写入存储器就固定不变,即使断电,内容也不会丢失
串行访问存储器对存储单元进行读/写操作时, 需按其物理位置的先后顺序寻址

4.按信息的可保存性分类

  • 断电后,存储信息即消失的存储器,称为易失性存储器,如RAM。
  • 断电后信息仍然保持的存储器,称为非易失性存储器,如ROM、磁表面存储器和光存储器。
  • 若某个存储单元所存储的信息被读出时,原存储信息被破坏,则称为破坏性读出;
  • 若读出时,被读单元原存储信息不被破坏,则称为非破坏性读出
  • 具有破坏性读出性能的存储器,每次读出操作后,必须紧接一个再生的操作,以便恢复被破坏的信息。

存储器的性能指标

存储器有3个主要性能指标,即存储容量、单位成本和存储速度。这3个指标相互制约,设
计存储器系统所追求的目标就是大容量、低成本和高速度。

  • 存储容量=存储字数x字长(如1Mx8位)。单位换算: 1B (Byte, 字节)=8b (bit, 位)。.
  • 单位成本:每位价格=总成本/总容量。
  • 存储速度:数据传输率=数据的宽度/存取周期(或称存储周期)。
  • ①存取时间(Tg):存取时间是指从启动一次存储器操作到完成该操作所经历的时间,分为读出时间和写入时间。
  • ②存取周期(Tm):存取周期又称读写周期或访问周期。它是指存储器进行- -次完整的读写操作所需的全部时间,即连续两次独立访问存储器操作(读或写操作)之间所需的最小时间间隔。
  • ③主存带宽(Bm):主存带宽又称数据传输率,表示每秒从主存进出信息的最大数量,单位为字/秒、字节/秒(B/s) 或位/秒(b/s)。
  • 存取时间不等于存取周期,通常存取周期大于存取时间。

 多级层次的存储系统

相联存储器是按( 内容指定方式和地址指定方式相结合 )进行寻址的存储器。

设机器字长为64位,存储容量为128MB,若按字编址,它可寻址的单元个数是16M

主存储器

DRAM和SRAM

主存储器由DRAM实现,靠处理器的那一层(Cache) 则由SRAM实现

DRAM常用的刷新方式有3种:

  • 集中刷新:指在一个刷新周期内,利用一段固定的时间,依次对存储器的所有行进行逐一再生。
  • 分散刷新:把对每行的刷新分散到各个工作周期中。
  • 异步刷新:异步刷新是前两种方法的结合。
     
是否有死时间特点
集中刷新优点是读写操作时不受刷新工作的影响;缺点是在集中刷新期间(死区)不能访问存储器
分散刷新没有优点是没有死区;缺点是加长了系统的存取周期,降低了整机的速度。
异步刷新缩短死时间既可缩短“死时间”,又能充分利用最大刷
新间隔为2ms的特点,提高了整机的工作效率

SRAM例题:某一SRAM芯片,其容量为1024x8位,除电源和接地端外,该芯片的引脚的最小数目为(A)。
A.21   B.22   C.23   D.24

芯片容量为1024x8位,说明芯片容量为1024B,且以字节为单位存取,即地址线数要10根
(1024B = 2^10B)。 8位说明数据线要8根,加上片选线和读/写控制线(读控制为RD、写控制为WE),因此引脚数最小为10 + 8 +1+2 = 21根
注意:读写控制线也可共用一根,但题中无20选项,做题时应随机应变。

DRAM例题:某一DRAM芯片,采用地址复用技术,其容量为1024x8 位,除电源和接地端外,该芯
片的引脚数最少是( ) (读写控制线为两根)。
A.16.
B.17
C.19
D.21

1024x8位,因此可寻址范围是1024B = 210B,按字节寻址。采用地址复用技术时,通过行通
选和列通选分行、列两次传送地址信号,因此地址线减半为5根,数据线仍为8根;加上行通选和列通选及读/写控制线(片选线用行通选代替)4根,总共是17根
注意SRAM和DRAM的区别,DRAM采用地址复用技术,而SRAM不采用

只读存储器

ROM器件的优点:

1) 结构简单,所以位密度比可读写存储器的高。
2) 具有非易失性,所以可靠性高
 

ROM的类型

根据制造工艺的不同,ROM可分为

  • 掩模式只读存储器(MROM)
  • 一次可编程只读存储器(PROM)
  • 可擦除可编程只读存储器(EPROM)
  • Flash 存储器
  • 固态硬盘(SSD)。
写入限制特点
掩模式只读存储器半导体制造厂按用户提出的要求在芯片的生产过程中直接写入优点是可靠性高,集成度高,价格便宜;缺点是灵活性差。
一次可编程只读存储器允许用户利用专门的设备(编程器)写入自己的程序允许用户利用专门的设备(编程器)写入自己
的程序,一旦写入,内容就无法改变。
可擦除可编程只读存储器不仅可以由用户利用编程器写入信息,而且可以对其内容进行多次改写由用户利用编程器写入信息,可以对其内容进行多次改写,编程次数有限,且写入时间过长。
Flash存储器在线进行快速擦除与重写可在不加电的情况下长期保存信息,又能在线进行快速擦除与重写
固态硬盘(Solid State Drives, SSD)保留了 Flash存储器长期保存信息、快速擦除与重写的特性读写速度快、低功耗的特性,缺点是价格较高

多模块存储器

多模块存储器是一种空间并行技术,利用多个结构完全相同的存储模块的并行工作来提高存储
器的吞吐率。常用的有单体多字存储器多体低位交叉存储器

单体多字存储器 

单体多字系统的特点是存储器中只有一个存储体,每个存储单元存储m个字,总线宽度也为m
物个字。一次并行读出m个字,地址必须顺序排列并处于同一存储单元。

多体并行存储器

器由多体模块组成。每个模块都有相同的容量和存取速度,各模块都有独立的读写控制电路地址寄存器数据寄存器。它们既能并行工作,又能交叉工作。

  • 高位交叉编址(顺序方式):填满一个模块,再填下一个
  • 低位交叉编址(交叉方式):讲究的是雨露均沾

高位交叉存储器在单个存储器中的字是连续存放的,不满足程序的局部性原理;

而低位交叉存储器是交叉存放,很好地满足了程序的局部性原理

主存器与CPU的连接 

这部分啊,还得自己做题,自己算

主存容量的扩展 

  • 位扩展法
  • 字扩展法
  • 字位同时扩展法

 存储芯片的地址分配和片选

线选法

  • 线选法用除片内寻址外的高位地址线直接(或经反相器)分别接至各个存储芯片的片选端,当某地址线信息为“0”时,就选中与之对应的存储芯片。这些片选地址线每次寻址时只能有一位有效
  • 优点:不需要地址译码器,线路简单。
  • 缺点:地址空间不连续,选片的地址线必须分时为低电平(否则不能工作),不能充分利用系统的存储器空间,造成地址资源的浪费。

译码片选法 

  • 译码片选法,即用一片74LS138作为地址译码器,则A15 A14 A13=000时选中第一片,
  • A15 A14 A13=001时选中第二片,以此类推(即3位二进制编码)。 

 存储器与CPU的连接

  1. 合理选择存储芯片
  2. 地址线的连接
  3. 数据线的连接
  4. 读/写命令线的连接
  5. 片选线的连接

外部存储器

磁盘存储器

最小读写单位是一个扇区

磁盘存储器的优点:

  • ①存储容量大,位价格低;
  • ②记录介质可重复使用;
  • ③记录信息可长期保存而不丢失,甚至可脱机存档;
  • ④非破坏性读出,读出时不需要再生。

缺点:存取速度慢,机械结构复杂,对工作环境要求较高。 

1.磁盘存储器

(1)磁盘设备的组成

① 硬盘存储器的组成。

  • 硬盘存储器由磁盘驱动器、磁盘控制器和盘片组成。·、

②存储区域。

  • 磁头数(Heads)
  • 柱面数(Cylinders)
  • 扇区数(Sectors)

 (3)磁盘的性能指标

①记录密度

  • 道密度(60道/cm)、位密度(100bit/cm)和面密度,面密度是位密度和道密度的乘积。

②磁盘的容量

  • 格式化后的容量比非格式化容量要小。

③平均存取时间。

  • 平均存取时间由寻道时间(磁头移动到目的磁道的时间)、旋转延迟时间(磁头定位到要读写扇区的时间)和传输时间(传输数据所花费的时间)三部分构成。由于寻道和找扇区的距离远近不一,故寻道时间和旋转延迟时间通常取平均值。

④数据传输率。

  • 磁盘存储器在单位时间内向主机传送数据的字节数,称为数据传输率。假设磁盘转数为r转/秒,每条磁道容量为N字节,则数据传输率为Dr=rN

(4)磁盘地址

若系统中有4个驱动器,每个驱动器带一个磁盘,每个磁盘256个磁道、16个盘面,每个盘面划分为16个扇区,则每个扇区地址要18位二进制代码,其格式如下图所示。

(5)硬盘的工作过程

  • 寻址、读盘、写盘。每个操作都对应一个控制字,硬盘工作时,第一步是取控制字,第二步是执行控制字。硬盘属于机械式部件,其读写操作是串行的,不可能在同一时刻既读又写,也不可能在同一时刻读两组数据或写两组数据。 

2.磁盘阵列 

  • 越往下,可靠性越高
  • RAID0:无冗余和无校验的磁盘阵列。
  • RAID1:镜像磁盘阵列。
  • RAID2:采用纠错的海明码的磁盘阵列。
  • RAID3:位交叉奇偶校验的磁盘阵列。
  • RAID4:块交叉奇偶校验的磁盘阵列。
  • RAID5:无独立校验的奇偶校验磁盘阵列。 

固态硬盘 

  • 固态硬盘基于闪存技术,没有机械部件,随机读写不需要机械操作,因此速度明显高于磁盘
  • SSD的缺点是容易磨损 ,随机写很慢

【2015统考真题】若磁盘转速为7200转/分,平均寻道时间为8ms,每个磁道包含1000个扇区,则访问一个扇区的平均存取时间大约是()。

A.8.1msB. 12.2msC.16.3msD. 20.5ms 

 高速缓冲器

这个人写得好:计组——彻底搞懂cache主存映射以及cache容量的计算_cache总容量怎么算-CSDN博客

我这里就放两个例题: 

标记cache行号块内地址
17105

主存快大小32B,所以块内地址为5位,2^5=32

一共32KB的数据区除以一个主存快大小32B=1K=2^10,所以行号这部分就是10

最后求标记:32-10-5=17

回写策略(脏位)要一位

有效位占一个

共计:17+1+1+32*8=275

 ​​​​​​

标记组号块内地址
2066

还是先从主存块抓起:

64B=2^6,所以块内地址占6位

求组号:

32KB除以64=2^9个行,2^9除以8=3^6,所以组号是6,(因为8路嘛,一组就有八个行,就得除以8)

标记:

32-6-6=20

比较器个数就是几路,8路所以就需要8个

比较器的位数是标记位:20

在组相联映射的Cache 中,“比较器”用于并行地比较分组中所有Cache行的Tag标记位与欲访问物理地址的Tag标记位,因此比较器的个数就是分组中的Cache行数8,比较器的位数就是Tag标记位数20。

相关文章:

计组之存储系统

存储器概述 分类 1.按在计算机中的作用(层次)分类 主存储器。CPU可以直接随机地对其进行访问,也可以和高速缓冲存储器(Cache)及辅助存储器交换数据。辅助存储器。辅存的内容需要调入主存后才能被CPU访问。高速缓冲存储器。位于…...

【Jenkins】新建任务FAQ

问题1. 源码管理处填入Repository URL,报错:无法连接仓库:Error performing git command: ls-remote -h https://github.com/txy2023/GolangLearning.git HEAD 原因: jenkins全局工具配置里默认没有添加git的路径,如果…...

生产环境使用boost::fiber

简介 boost::fiber是一类用户级线程,也就是纤程。其提供的例子与实际生产环境相距较远,本文将对其进行一定的改造,将其能够投入到生产环境。 同时由于纤程是具有传染性的,使用纤程的代码里也全部要用纤程封装,本文将对…...

TSINGSEE青犀AI视频识别技术+危化安全生产智慧监管方案

一、背景分析 石油与化学工业生产过程复杂多样,涉及的物料易燃易爆、有毒有害,生产条件多高温高压、低温负压,现场危险化学品存储量大、危险源集中,重特大安全事故多发。打造基于工业互联网的安全生产新型能力,提高危…...

小程序request请求封装

以上为本人的项目目录 1.首先在utils中创建request.js文件封装request请求,此封装带上了token,每次请求都会自带token,需要你从后端获取后利用wx.setStorageSync(token,返回的token),不使用的话就是空。 直接复制即可,需要改一下…...

Easy Javadoc插件的使用教程

目录 一、安装Easy Javadoc插件 二、配置注释模板 三、配置翻译 一、安装Easy Javadoc插件 在idea的File-Settings-Plugins中搜索Easy Javadoc插件,点击install进行安装,安装完成后需要restart IDE,重启后插件生效。 二、配置注释模板 …...

一篇文章让你弄懂Java中的方法

目录 1. 方法概念及使用 1.1 什么是方法(method) 1.2 方法定义 1.3 方法调用的执行过程 1.4 实参和形参的关系 1.5 没有返回值的方法 2. 方法重载 2.1 为什么需要方法重载 2.2 方法重载概念 2.3 方法签名 1. 方法概念及使用 1.1 什么是方法(method) 方法就是一…...

SAP MM学习笔记39 - MRP(资材所要量计划)

这一章开始,离开请求书,学点儿新知识啦。 MRP ( Material Requirement Planning ) - 资材所要量计划。 它的位置在下面的调达周期图上来看,就是右上角的 所要量决定那块儿。 1,MRP(资材所要量计划) 的概要 MRP 的主要目的就是 确…...

总线类设备驱动——IIC

目录 一、本章目标 二、IIC设备驱动 2.1 I2C协议简介 2.2 LinuxI2C驱动 2.3 I2C 设备驱动实例 一、本章目标 一条总线可以将多个设备连接在一起,提高了系统的可扩展性能。这个互联的系统通常由三部分组成:总线控制器、物理总线(一组信号线) 和设备。总线控制器…...

MES 的价值点之动态调度

随着数字化技术的发展,为制造企业的生产计划提供了更多的便利。但在实际生产管理过程中,企业的生产计划不管做的多么理想,还是可能会因诸多的扰动因素造成执行与计划差异,这时就需要通过一些动态调整方案去适应新的生产要求与环境…...

dfs序及相关例题

常用的三种dfs序 欧拉序 每经过一次该点记录一次的序列。 dfs序 记录入栈和出栈的序列。 dfn序 只记录入栈的序列。 dfs序 DFS 序列是指 DFS 调用过程中访问的节点编号的序列。 如何求dfs序&#xff1f;可以用以下代码来找dfs序。 vector<vector<int>> g(n…...

python入门实战:爬取图片到本地

简单记录一下爬取网站图片保存到本地指定目录过程,希望对刚入门的小伙伴有所帮助! 目标网站就是下图所示页面: 实现步骤: 1.爬取每页的图片地址集合 2.下载图片到本地 3. 获取指定页数的页面路径 以下是实现代码: import bs4 import requests import os # 下…...

day02 矩阵 2023.10.26

1.矩阵 2.矩阵乘法 3.特殊矩阵 4.逆矩阵 5.正交矩阵 6.几何意义 7.齐次坐标 8.平移矩阵 9.旋转矩阵 10.缩放矩阵 11.复合运算...

浪潮信息inMerge超融合 刷新全球vSAN架构虚拟化VMmark最佳成绩

近日&#xff0c;在国际权威的VMmark测试中&#xff0c;浪潮信息inMerge1100超融合产品搭载NF5280M7服务器&#xff0c;满载运行44Tiles取得40.95分的成绩&#xff0c;刷新了vSAN架构&#xff08;Intel双路最新平台&#xff09;虚拟化性能测试纪录。该测试结果证明inMerge1100可…...

【【哈希应用】位图/布隆过滤器】

位图/布隆过滤器 位图位图概念位图的使用位图模拟实现 布隆过滤器布隆过滤器概念布隆过滤器的使用布隆过滤器模拟实现 位图/布隆过滤器应用&#xff1a;海量数据处理哈希切分 位图 位图概念 计算机中通常以位bit为数据最小存储单位&#xff0c;只有0、1两种二进制状态&#x…...

OpenCV学习笔记

一、OpenCV基础 &#xff08;一&#xff09;图像的读取、显示、创建 https://mp.weixin.qq.com/s?__bizMzA4MTA1NjM5NQ&mid2247485202&idx1&sn05d0b4cd25675a99357910a5f2694508&chksm9f9b80f6a8ec09e03ab2bb518ea6aad83db007c9cdd602c7459ed75c737e380ac9c3…...

idea 一键部署jar包

上传成功...

16、SpringCloud -- 常见的接口防刷限流方式

目录 接口防刷限流方式1:隐藏秒杀地址需求:思路:代码:前端:后端:测试:总结:方式2:图形验证码1、生成图形验证码需求:思路:代码:前端:后端:测试:2、校验验证码需求:思路:代码:...

Typora(morkdown编辑器)的安装包和安装教程

Typora&#xff08;morkdown编辑器&#xff09;的安装包和安装教程 下载安装1、覆盖文件2、输入序列号①打开 typora &#xff0c;点击“输入序列号”&#xff1a;②邮箱一栏中任意填写&#xff08;但须保证邮箱地址格式正确&#xff09;&#xff0c;输入序列号&#xff0c;点击…...

服务器不稳定对网站有什么影响

世界上最远的距离&#xff0c;不是树枝无法相依&#xff0c;而是相互了望的星星&#xff0c;却没有交汇的轨迹。 现代技术的进步&#xff0c;导致了人与人之间距 离的消除&#xff0c;直播行业的快速发展的影响和渗透进如今的日常生活&#xff0c;为人们在遥远的距离相见与互诉…...

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…...

C++初阶-list的底层

目录 1.std::list实现的所有代码 2.list的简单介绍 2.1实现list的类 2.2_list_iterator的实现 2.2.1_list_iterator实现的原因和好处 2.2.2_list_iterator实现 2.3_list_node的实现 2.3.1. 避免递归的模板依赖 2.3.2. 内存布局一致性 2.3.3. 类型安全的替代方案 2.3.…...

label-studio的使用教程(导入本地路径)

文章目录 1. 准备环境2. 脚本启动2.1 Windows2.2 Linux 3. 安装label-studio机器学习后端3.1 pip安装(推荐)3.2 GitHub仓库安装 4. 后端配置4.1 yolo环境4.2 引入后端模型4.3 修改脚本4.4 启动后端 5. 标注工程5.1 创建工程5.2 配置图片路径5.3 配置工程类型标签5.4 配置模型5.…...

【OSG学习笔记】Day 18: 碰撞检测与物理交互

物理引擎&#xff08;Physics Engine&#xff09; 物理引擎 是一种通过计算机模拟物理规律&#xff08;如力学、碰撞、重力、流体动力学等&#xff09;的软件工具或库。 它的核心目标是在虚拟环境中逼真地模拟物体的运动和交互&#xff0c;广泛应用于 游戏开发、动画制作、虚…...

《从零掌握MIPI CSI-2: 协议精解与FPGA摄像头开发实战》-- CSI-2 协议详细解析 (一)

CSI-2 协议详细解析 (一&#xff09; 1. CSI-2层定义&#xff08;CSI-2 Layer Definitions&#xff09; 分层结构 &#xff1a;CSI-2协议分为6层&#xff1a; 物理层&#xff08;PHY Layer&#xff09; &#xff1a; 定义电气特性、时钟机制和传输介质&#xff08;导线&#…...

Android 之 kotlin 语言学习笔记三(Kotlin-Java 互操作)

参考官方文档&#xff1a;https://developer.android.google.cn/kotlin/interop?hlzh-cn 一、Java&#xff08;供 Kotlin 使用&#xff09; 1、不得使用硬关键字 不要使用 Kotlin 的任何硬关键字作为方法的名称 或字段。允许使用 Kotlin 的软关键字、修饰符关键字和特殊标识…...

Fabric V2.5 通用溯源系统——增加图片上传与下载功能

fabric-trace项目在发布一年后,部署量已突破1000次,为支持更多场景,现新增支持图片信息上链,本文对图片上传、下载功能代码进行梳理,包含智能合约、后端、前端部分。 一、智能合约修改 为了增加图片信息上链溯源,需要对底层数据结构进行修改,在此对智能合约中的农产品数…...

深度学习水论文:mamba+图像增强

&#x1f9c0;当前视觉领域对高效长序列建模需求激增&#xff0c;对Mamba图像增强这方向的研究自然也逐渐火热。原因在于其高效长程建模&#xff0c;以及动态计算优势&#xff0c;在图像质量提升和细节恢复方面有难以替代的作用。 &#x1f9c0;因此短时间内&#xff0c;就有不…...

RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)

RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发&#xff0c;后来由Pivotal Software Inc.&#xff08;现为VMware子公司&#xff09;接管。RabbitMQ 是一个开源的消息代理和队列服务器&#xff0c;用 Erlang 语言编写。广泛应用于各种分布…...

STM32HAL库USART源代码解析及应用

STM32HAL库USART源代码解析 前言STM32CubeIDE配置串口USART和UART的选择使用模式参数设置GPIO配置DMA配置中断配置硬件流控制使能生成代码解析和使用方法串口初始化__UART_HandleTypeDef结构体浅析HAL库代码实际使用方法使用轮询方式发送使用轮询方式接收使用中断方式发送使用中…...