第3章 存储系统(2)

3.3 主存储器与CPU连接

3.3.1 连接原理

现代计算机的MAR和MDR都在CPU内部
(1)主存储器通过数据总线,地址总线,控制总线与CPU连接。
(2)数据传输率=数据总线宽度*总线频率
(4)控制总线(读写线)控制读写操作。
在这里插入图片描述


3.3.2 主存的扩展

数据总线宽度等于存储字长

  • 1.位扩展法【增加存储字长,发挥数据总线的传输能力】

    • 将数据总线的不同线连接不同的存储芯片,属于同一个地址的不同的比特位。
    • 地址线连接方式相同。
    • 数据线连接方式不同。
    • CS片选信号需要连接全部芯片
    • 例如使用8个8k*1位的的芯片改造成8k*8位的芯片 在这里插入图片描述
  • 2.字扩展法【增加存储器的字数,更好利用CPU的寻址能力,扩大寻址范围】

    • 同一根数据线地址线连接多个芯片。
    • 使用片选线控制同一地址不同芯片读取顺序。
    • 地址线的低位用于芯片内部寻址,地址线的高位用于芯片定位。地址线高位输入到地址译码器后转换成具体芯片编号。【大部分情况是这样,具体题目具体分析】。
    • 在这里插入图片描述

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

  • 1.线选法
    使用一个地址线对应一个芯片

    优点:不需要地址译码器。

    缺点:不能使用连续空间。

    • 原因:
      • 如下图所示A13,A14只能取值10或01。【不能为11同时存取】
      • 其空间范围是(10 0000....000010 1111...1111)和(01 0000...000001 1111...1111)。
      • 其中00 xxxx…xxxx和11 xxxx…xxxx空间没有使用到。
        在这里插入图片描述
  • 2.译码片选法
    n条地址线经过译码器可以转化成 2 n 2^n 2n个不同的芯片编号

    优点:地址空间连续。

    • 以A13,A15为片选信号为例。
    • 片选信号的A14为无效信号,可以为任何值。
    • 而A13和A15决定了芯片选取。第一个0x0,第二个0x1,第三个1x0,第四个1x1。 在这里插入图片描述

3.3.4 存储器与CPU的连接

  • 地址线的连接:
    CPU地址线的低位与存储芯片的地址线连接。高位是在扩充芯片时使用,选择具体芯片。
  • 数据线的连接:
    CPU数据线与存储器芯片不一定相等,相等可以直接连接。不相等时需要进行芯片位扩展
  • 读写控制线:
    读写线控制读写操作。可设计成两根,也可以一根。
  • 片选线的连接:
    芯片被选中由片选信号决定。由CPU通过CS传递给芯片。

3.4 外部存储器

3.4.1 磁盘存储器

  • 优点:
    ①容量大,位价格低
    ②记录介质可以重复使用
    ③记录信息可以长期保存
    非破坏读出

  • 缺点:
    ①读取速度慢
    ②机械结构复杂

1.磁盘存储器:

  • 磁盘存储器组成:磁盘驱动器,磁盘控制器,盘片。
  • 存储区域组成:磁头,柱面,扇区(扇区是读写的基本单位)
  • 磁盘指标:
    • 记录密度:
      • 道密度: 磁道个数除以磁盘半径。
      • 位密度: 磁道单位长度的二进制代码位数。【由于每个区块中数据量相同,越靠近内部,区块越小,密度越大】
      • 面密度: 位密度乘以道密度。
    • 磁盘容量:格式化后的容量变小。
    • 平均存取时间: 寻道时间(磁头移动时间)+旋转时间(定位扇区时间)+传输时间(传输数据时间)
    • 数据传输率:理论速率=磁盘转速r*磁道容量N字节
      D r = r N D_r=rN Dr=rN
  • 磁盘地址:
磁盘驱动器号[硬盘号]柱面(磁道)号[磁头臂移动]磁面号[激活磁头]扇区号

2.磁盘阵列:

RAID0无冗余,无校验,无容错能力,条带化,提高存取速度
RAID1有容错能力,代价是容量减半
RAID2-RAID5通过校验提高容错能力
总结通过多个磁盘,提高传输率。并行提高数据吞吐量,镜像提高安全可靠性,数据校验位提供容错能力。

3.4.2 固态硬盘

固态硬盘(SSD)基于闪存技术的存储技术。
S S D 组成 = { 一个或多个闪存芯片 闪存翻译层【用于将逻辑块号映射到对应的物理地址】 SSD组成 = \begin{cases} 一个或多个闪存芯片\\ 闪存翻译层【用于将逻辑块号映射到对应的物理地址】 \end{cases} SSD组成={一个或多个闪存芯片闪存翻译层【用于将逻辑块号映射到对应的物理地址】
数据读写单位:页。【IO总线指明逻辑块号,映射成页号】
页内有数据,不允许写入数据。重新写入数据到页中需要将一整块擦除重新写入。 【先将旧数据放入新物理地址,再重新写入,最后修改闪存翻译层的映射地址】。写比读慢。
在这里插入图片描述
对比:

固态硬盘机械硬盘
扇区
磁道

在这里插入图片描述

  • 缓轻磨损:
    • 1.动态磨损:优先选择累计擦除次数少的闪存块。
    • 2.静态磨损:将读多写少的数据迁移到被多次擦除的区域。

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

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

相关文章

离线数据同步工具DataX

目录 1.应用场景2.类似的数据同步工具3.DataX 与 Canal 有什么区别 DataX是阿里巴巴开源的一款数据同步工具,使用Java语言开发的。它提供了从各类数据源读取数据以及向各类数据源写入数据的功能,支持包括MySQL、Oracle、SQLServer、PostgreSQL、HDFS、HB…

2024/4/6 HarmonyOS学习笔记-图片组件

Image组件 1、作用: 渲染并展示图片,支持本地和网络图片。 Image($r(‘app.media.logo’)).width(78).height(78) 2、图片数据源 (1)string数据源: 适用于网络图片和本地图片 使用网络图片时需要在module.json5文…

STL、Vector和Set的讲解和例题分析

STL STL(Standard Template Library,标准模板库)是C标准库的一部分,它提供了一系列通用的编程组件,包括容器、迭代器、算法和函数对象等。STL是C中实现泛型编程的核心,它允许程序员使用模板编写与数…

Java-Web过滤器

文章目录 1.基本介绍1.为什么需要过滤器?2.基本介绍3.过滤器的基本原理 2.快速入门1.文件目录2.环境配置创建maven项目,导入依赖 3.代码实现1.login.jsp2.LoginCheck.java3.ManagerFilter.java编写过滤规则4.配置web.xml告诉tomcat5.admin.jsp 3.Filter的…

springboot如何切换内置web服务器?

切换内置web服务器 这是没有引入web依赖的服务 这是引入web依赖的服务 由此可知默认是tomcat服务器 那么如何切换内置服务器 只要有对应服务器的坐标即可自动切换&#xff0c;先排除tomcat再引入依赖&#xff0c;比如切换成jetty服务器 <dependency><groupId>org…

rabbitmq的消息确认机制和消息持久化机制分别是如何实现的?

RabbitMQ的消息确认机制和消息持久化机制是确保消息可靠传输和存储的重要功能。下面是它们各自的工作原理的简要说明&#xff1a; 1、消息确认机制 RabbitMQ的消息确认机制主要用于确保消息从生产者发送到队列&#xff0c;以及从队列发送到消费者时都能够被正确处理和确认。这…

飞腾银河麒麟(ARM架构)离线安装MySql8.0.28版本

下载安装包 下载地址&#xff1a;https://downloads.mysql.com/archives/community/ 解压后上传到服务器(或者直接上传到服务器用tar -zxvf xxx.tar命令解压) 卸载mariadb 卸载命令&#xff1a;yum remove mariadb-server mariadb 检查是否还有未删除的包&#xff1a; rpm -…

模型训练----apex库报错IndexError: tuple index out of range

问题描述 在训练模型的过程中遇到了apex库的报错IndexError: tuple index out of range导致无法训练。在github查询后找到了解决方法 问题解决 需要修改/apex-master/apex/amp/utils.py这个文件的代码 从93行开始修改 if x in cache:cached_x cache[x]next_functions_ava…

【UE Niagara】蓝图获取粒子数据

目录 效果 步骤 一、创建粒子 二、创建蓝图接收Niagara参数 效果 步骤 一、创建粒子 1. 新建一个Niagara发射器&#xff0c;使用Empty模板&#xff0c;打开后先添加“Spawn Rate”模块&#xff0c;这里设置粒子生成速率为0.7 在“Initialize Particle”模块中设置粒子颜色…

Linux中的符号链接和硬链接

ln -s 是在Linux系统中用来创建符号链接&#xff08;symbolic link&#xff09;的命令。符号链接也称为软链接&#xff0c;它是一个特殊的文件&#xff0c;对另一个文件或目录建立了一个符号连接&#xff0c;类似于Windows系统中的快捷方式。 ln -s 命令的作用&#xff1a; 创…

【PostgreSql】只删除整个数据库的表(不删除数据库)

目录 查询数据库所有的表&#xff08;假设表都在public模式下&#xff09;清空数据库下所有的表 环境&#xff1a;windows数据库&#xff1a;postgresql 前提&#xff1a; 此方法用来删除数据库所有的表&#xff0c;不包括保存的函数语句、查询语句等&#xff08;可适用于需要…

Eland上传bge-base-zh-v1.5向量化模型到ElasticSearch中

最近需要做一些向量检索&#xff0c;试试ES 一、准备 系统&#xff1a;MacOS 14.3.1 ElasticSearch&#xff1a;8.13.2 Kibana&#xff1a;8.13.2 本地单机环境&#xff0c;无集群&#xff0c;也不基于Docker BGE是一个常见的文本转向量的模型&#xff0c;在很多大模型RAG应…

MobX 中 runInAction 的威力:构建原子性状态更新

"原子性状态更新"这个词可以很好地概括 runInAction 的核心功能,即将一组相关的状态更新作为一个整体,要么全部成功,要么全部失败。这种特性对于复杂的异步操作和状态管理非常重要。可以帮助我们构建更加可靠和可预测的 React 应用程序。 怎么理解原子性操作 "…

华为OD技术面试-爬楼计数(动态规划)

背景 2024-03-16 华为od 技术面试&#xff0c;记录题目和模型 题目 分析 入门级的 动态规划算法&#xff0c;直接写就行了 缓存递归 代码 DZs {} def climbStairs(n):if n<0:return 0if DZs.get(n, 0)>0 :return DZs[n]if n2:jf 2elif n1:jf 1;else:jf1 climb…

Oozie工作流管理系统设计与实践:面试经验与必备知识点解析

本文将深入探讨Oozie的工作流设计、实践技巧,以及面试必备知识点与常见问题解析,助你在面试中展现出深厚的Oozie技术功底。 一、Oozie工作流管理系统基础 1.Oozie简介与安装配置简述Oozie的发展历程、主要功能、适用场景,以及如何下载、安装、配置Oozie(包括环境变量设置、…

vue2+codemirror实现在线编辑java代码(一 配置)

使用vue2+codemirror实现java代码回显和编辑功能。 效果图如下: 1、安装 vue-codemirror // 指定安装4.x版本 // 目前最新版本6.x,仅支持Vue3.0 npm i vue-codemirror@4.x --save// codemirror 需要与 vue-codemirror 同时安装 npm i codemirror@5.x --save 2、引入配置文…

javaee前后端交互

1.选择Java Enterprise创建项目 2.勾选Web Profile 3.项目名称 4.创建包和类 5.继承HttpServlet并重写方法doGet和doPost 6.在web.xml里添加代码 7.点击Add Configuration,进去后点击加号 8.选择选项 9.调整如图&#xff0c;后选择Deployment进入 10.点击加号选择第一个 11.…

练习4-10 找出最小值

本题要求编写程序&#xff0c;找出给定一系列整数中的最小值。 输入格式&#xff1a; 输入在一行中首先给出一个正整数n&#xff0c;之后是n个整数&#xff0c;其间以空格分隔。 输出格式&#xff1a; 在一行中按照“min 最小值”的格式输出n个整数中的最小值。 输入样例…

异常java

异常的两种处理方式 捕获异常&#xff0c;记录异常并响应合适的信息给用户捕获异常尝试重新修复 自定义运行时异常 定义一个异常类继承RunTimeException重写构造器通过throw new异常类&#xff08;xxx&#xff09;来创建异常对象并抛出 public class ExceptionTest2 { public…

Java二叉树(2)

一、二叉树的链式存储 二叉树的存储分为顺序存储和链式存储 &#xff08;本文主要讲解链式存储&#xff09; 二叉树的链式存储是通过一个一个节点引用起来的&#xff0c;常见的表示方式有二叉三叉 // 孩子表示法 class Node { int val; // 数据域 Node left; // 左孩子的引用…