第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,一经查实,立即删除!

相关文章

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…

飞腾银河麒麟(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”模块中设置粒子颜色…

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…

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.…

Java二叉树(2)

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

我为什么选择成为程序员?

前言&#xff1a; 我选择成为程序员不是兴趣所在&#xff0c;也不是为了职业发展&#xff0c;全是生活所迫&#xff01; 第一章&#xff1a;那年&#xff0c;我双手插兜&#xff0c;对外面的世界一无所知 时间回到2009年&#xff0c;时间过得真快啊&#xff0c;一下就是15年前…

6.12物联网RK3399项目开发实录-驱动开发之UART 串口的使用(wulianjishu666)

嵌入式实战开发例程【珍贵收藏&#xff0c;开发必备】&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1tkDBNH9R3iAaHOG1Zj9q1Q?pwdt41u UART 使用 简介 AIO-3399J 支持 SPI 桥接/扩展 4 个增强功能串口&#xff08;UART&#xff09;的功能&#xff0c;分别为 UA…

如何在群晖本地搭建在线PS工具Potopea并实现无公网IP远程编辑图片

文章目录 1. 部署Photopea2. 运行Photopea3. 群晖安装Cpolar4. 配置公网地址5. 公网访问测试6. 固定公网地址 本文主要介绍如何在群晖NAS使用Docker部署Potopea在线图片编辑工具&#xff0c;并结合cpolar内网穿透实现公网环境可以远程访问本地部署的Potopea. Photopea是一款强大…

[通俗易懂]《动手学强化学习》学习笔记2-第2、3、4章

文章目录 前言小总结&#xff08;前文回顾&#xff09;第二章 多臂老虎机2.2.2形式化描述 第三章 马尔可夫决策过程3.6 占用度量 代码3.6 占用度量 定理2 第四章 动态规划算法4.3.3 策略迭代算法 代码 总结 前言 参考&#xff1a; 《动手学强化学习》作者&#xff1a;张伟楠&a…

爬取豆瓣(线程、Session)优化版本

爬取豆瓣&#xff08;线程、Session&#xff09;优化版本 该文章只是为了精进基础&#xff0c;对Session、threading、网站请求解析的理解。 此版本没有爬取详情页。还在学习阶段的读者可以尝试一下。 适用于基础刚开始学习爬虫的&#xff01; 1.改进点&#xff1a; 将普通的r…

利用alibaba.item_get API接口,跨境电商如何快速获取商品详情?

利用alibaba.item_get API接口&#xff0c;跨境电商可以快速获取商品详情&#xff0c;为业务的开展提供有力支持。alibaba.item_get API接口是阿里巴巴开放平台提供的一项服务&#xff0c;它允许开发者通过调用API接口&#xff0c;获取阿里巴巴平台上商品的详细信息。以下是如何…

Android8.1 代码编译报错

注&#xff1a; 本文只是博主学习记录分享&#xff0c;仅供参考。如有错误肯定是博主理解有问题&#xff0c;谢谢&#xff01; 1. Android8.1 编译报 java 环境错误 1.1. 具休描述 Android8.1 代码编译报 Failed to run java: exce: "java": excutable file not fo…

【全网独家】oceanbase容器重启时报obshell failed错误,无法正常启动的问题处理

正常运行的oceanbase容器&#xff0c;重新启动该容器却启动不了&#xff0c;重启服务器也无法恢复&#xff0c;报obshell failed错误&#xff0c;无法正常启动&#xff0c;本文记录了问题处理过程。 一、问题现象 1、正常运行的oceanbase容器&#xff0c;重启却启动不了 2、运…

使用Charles断点修改接口返回数据

问题&#xff1a;数量/金额原来接口是用一个字段返回&#xff0c;由于业务需要换行展示&#xff0c;后端便拆分成了两个字段&#xff0c;前端则需要用新拆分的字段去取值&#xff0c;导致目前发现有个字段的金额也取成了件数&#xff08;红框部分&#xff09;&#xff1b;需求&…