系统架构设计师①:计算机组成与体系结构

news2024/11/14 20:31:33

系统架构设计师①:计算机组成与体系结构

计算机结构

计算机的组成结构可以概括为以下几个主要部分:中央处理器(CPU)、存储器(包括主存和外存)、输入设备、输出设备,以及控制器、运算器、总线和输入/输出控制器等关键组件。
在这里插入图片描述

CPU组成

CPU由运算器和控制器组成。

运算器:
①算术逻辑单元ALU:数据的算术运算和逻辑运算
②累加寄存器AC:通用寄存器,为ALU提供一个工作区,用在暂存数据
③数据缓冲寄存器DR:写内存时,暂存指令或数据
④状态条件寄存器PSW:存状态标志与控制标志(争议:也有将其归为控制器的)

控制器:
①程序计数器PC:存储下一条要执行指令的地址
②指令寄存器IR:存储即将执行的指令
③指令译码器ID:对指令中的操作码字段进行分析解释
④时序部件:提供时序控制信号

存储系统

主流存储系统分为冯·诺依曼结构和哈佛结构。

冯·诺依曼结构

冯·诺依曼结构也称普林斯顿结构,是一种将程序指令存储器和数据存储器合并在一起的存储器结构。

特点:
(1)一般用于PC处理器,如I3,I5,I7处理器
(2)指令与数据存储器合并在一起
(3)指令与数据都通过相同的数据总线传输

哈佛结构

哈佛结构是一种将程序指令存储和数据存储分开的存储器结构。哈佛结构是一种并行体系结构,它的主要特点是将程序和数据存储在不同的存储空间中,即程序存储器和数据存储器是两个独立的存储器,每个存储器独立编址、独立访问。

特点:
(1)一般用于嵌入式系统处理器(DSP)数字信号处理(DSP,DigitalSignalProcessing)
(2)指令与数据分开存储,可以并行读取,有较高数据的吞吐率
(3)有4条总线:指令和数据的数据总线与地址总线

层次化存储结构

按照存储速度划分存储器可分为寄存器、Cache、内存、外存。
其速度排列如下图所示:(存取速度越快,其硬件成本越高)
在这里插入图片描述

Cache(高速缓存)存在的目的是为了解决CPU和内存速度不匹配的问题

Cache

Cache的功能:提高CPU数据输入输出的速率,突破冯·诺依曼瓶颈,即CPU与存储系统间数据传送带宽限制。

在计算机的存储系统体系中,Cache是访问速度最快的层次。
Cache对程序员来说是透明的。
使用Cache改善系统性能的依据是程序的局部性原理。
①时间局部性
②空间局部性

时间局部性:指程序中的某条指令一旦执行,不久以后该指令可能再次执
行,典型原因是由于程序中存在着大量的循环操作(如for循环中的i变量)。

空间局部性:指一旦程序访问了某个存储单元,不久以后,其附近的存储
单元也将被访问,即程序在一段时间内所访问的地址可能集中在一定的范
围内,其典型情况是程序顺序执行(如数组的遍历)。

工作集理论:工作集是进程运行时被频繁访问的页面集合。

Cache计算公式

如果以h代表对Cache的访问命中率,t1表示Cache的周期时间,t2表示主存储器周期时间,以读操作为例,使用“Cache+主存储器”的系统的平均周期为t3,则:

t3=h*t1+(1-h)*t2          /* 其中,(1-h)又称为失效率(未命中率) */

主存编址

存储单元

存储单元个数=最大地址-最小地址+1

1字节(Byte)= 8位(bit):这是计算机存储单位的基础换算关系,字节是数据存储的基本单位,而位是计算机中最小的存储单元。

32位系统:1字 = 32位 = 4字节
64位系统:1字 = 64位 = 8字节

编址内容
按字编址:存储体的存储单元是字存储单元,即最小寻址单位是一个字
按字节编址:存储体的存储单元是字节存储单元,即最小寻址单位是一个字节

总容量=存储单元个数*编址内容

根据存储器所要求的容量和选定的存储芯片的容量,就可以计算出所需的芯片总数,即:

总片数=总容量/每片的容量

磁盘基本结构与存取过程

磁盘管理

磁盘结构如图所示:
在这里插入图片描述

存取时间=寻道时间+等待时间

寻道时间:磁头移动到磁道所需的时间;
等待时间:等待读写的扇区转到磁头下方所用的时间

读取磁盘数据的时间包括以下三个部分
①找磁道的时间。
②找块(扇区)的时间,即旋转延迟时间。
③传输时间。

平均存取时间(Average Access Time),是指磁头找到指定数据的平均时间。
平均存取时间是指磁头找到指定数据的平均时间,通常它是硬盘平均寻道时间和平均潜伏时间(等待时间)之和。
平均存取时间最能代表硬盘找到某一数据所用的时间,数值越小越好。

平均访问时间=平均寻道时间+平均等待时间

磁盘移臂调度算法

先来先服务(FCFS, First Come First Serve)
定义:FCFS是最简单的调度算法,按照作业提交或进程变为就绪状态的先后次序,分派CPU。当前作业或进程占用CPU,直到执行完或阻塞,才出让CPU(非抢占方式)。在作业或进程唤醒后(如I/O完成),并不立即恢复执行,通常等到当前作业或进程出让CPU。
优点:有利于CPU繁忙的作业,而不利于I/O繁忙的作业。
缺点:比较有利于长作业,而不利于短作业,因为长作业会长时间占据处理机。

最短寻道时间优先(SSTF, Shortest Seek Time First)
定义
SSTF选择这样的进程,其要求访问的磁道与当前磁头所在的磁道距离最近,以使每次的寻道时间最短。
优点:SSTF算法的平均每次磁头移动距离明显低于FCFS的距离,具有较好的寻道性能。
缺点:不能保证平均寻道时间最短,且有可能产生饥饿现象,即磁头有可能在一个小区域内来回来去地移动,导致某些磁道的请求长时间得不到服务。

扫描算法(SCAN)
定义:
SCAN算法,又称电梯算法,磁头按一个方向移动,直到遇到最远的请求,然后返回磁盘的另一端。
优点:可以平均分配磁盘访问的时间,避免磁头频繁地改变移动方向,减少了磁头的移动距离和寻道时间。
缺点:对于各个位置磁道的响应频率不平均,可能会导致某些磁道的请求长时间等待。

循环扫描算法(CSCAN, Circular SCAN)
定义:

CSCAN是对SCAN算法的一种改进。它规定磁头只做单向移动,当磁头移到最外的被访问磁道时,磁头立即返回到最里的欲访磁道,即将最小磁道号紧接着最大磁道号构成循环,进行扫描。
优点:减少了磁头的移动次数和寻道时间,提高了磁盘访问效率,同时避免了SCAN算法中磁头频繁改变移动方向的问题。
缺点:在某些情况下,仍然可能存在磁道请求长时间等待的问题,但相较于SCAN算法,这种情况有所改善。

数据传输控制方式

程序控制(查询)方式:分为无条件传送和程序查询方式两种。
方法简单,硬件开销小,但I/O能力不高,严重影响CPU的利用率。

程序中断方式:与程序控制方式相比,中断方式因为CPU无需等待而提高了传输请求的响应速度。

DMA方式:DMA方式是为了在主存与外设之间实现高速、批量数据交换而设置的。DMA方式比程序控制方式与中断方式都高效。

(DMAC向总线裁决逻辑提出总线请求;CPU执行完当前总线周期即可释放总线控制权。此时DMA响应,通过DMAC通知I/O接口开始DMA传输。)

其他方式:
通道方式
I/O处理机

总线

总线:是一组能为多个部件分时共享的公共信息传送线路
特点
①共享
②分时:是指同一时刻仅允许一个部件向总线发送信息,但允许多个部件同时从总线上接受相同的信息。
③分为串行总线(适合长距离传输)与并行总线(适合近距离连接,不宜过长)
④通信方式分为单工、半双工与全双工

总线宽度与总线带宽
总线的分类:
数据总线(Data Bus,DB):在CPU与RAM之间来回传送需要处理或是需要储存的数据。
地址总线(Address Bus,AB):用来指定在RAM(Random Access Memory)之中储存的数据的地址。
控制总线(ControlBus,CB):将微处理器控制单元(ControlUnit)的信号,传送到周边设备。

CISC与RISC

复杂指令集计算机(CISC,ComplexInstruction Set Computers)
精简指令集计算机(RISC,ReducedInstruction Set Computers)
在这里插入图片描述

流水线

流水线是指:在程序执行时多条指令重叠进行操作的一种准并行处理实现技术。
各种部件同时处理是针对不同指令而言的,它们可同时为多条指令的不同部分进行工作,以提高各部件的利用率和指令的平均执行速度

在这里插入图片描述
流水线计算公式:一条指令执行时间+(指令条数-1)*流水线周期
①理论公式:(t1+t2+…+tk)+(n-1)*t在这里插入图片描述

②实践公式:k*t+(n-1)*t在这里插入图片描述
流水线周期:
在这里插入图片描述
一条指令的执行过程可以分解为取指、分析和执行三步

流水线的相关性能计算

**流水线的吞吐率(Though Putrate,TP)**是指在单位时间内流水线所完成的任务数量或输出的结果数量。
计算流水线吞吐率的最基本的公式如下:
在这里插入图片描述

流水线最大吞吐率:(占用周期最长的那一步所使用的时间的倒数)
在这里插入图片描述
流水线的加速比:
定义:完成同样一批任务,不使用流水线所用的时间与使用流水线所用的时间之
比称为流水线的加速比。
计算流水线加速比的基本公式如下:(加速比一定大于一)
在这里插入图片描述

校验码

奇偶校验码

奇偶校验码的编码方法是:由若干位有效信息(如一个字节),再加上一个二进制位(校验位)组成校验码。

奇校验:整个校验码(有效信息位和校验位)中“1”的个数为奇数。
偶校验:整个校验码(有效信息位和校验位)中“1”的个数为偶数。

奇偶校验,可检查1位的错误,不可纠错。

循环校验码CRC

CRC的编码方法是:在k位信息码之后拼接r位校验码。应用CRC码的关键是如何从k位信息位简便地得到r位校验位(编码),以及如何从k+r位信息码判断是否出错。

CRC校验,可检错,不可纠错

循环冗余校验码编码规律如下
① 把待编码的N位有效信息表示为多项式M(X);
② 把M(X)左移K位,得到M(X)*X的K次方,这样空出了K位,以便拼装K位余数(即校验位)
③ 选取一个K+1位的产生多项式G(X),对M(X)*X的K次方做模2除;
④ 把左移K位以后的有效信息与余数R(X)做模2加减,拼接为CRC码,此时的CRC码共有N+K位。

把接收到的CRC码用约定的生成多项式G(X)去除,如果正确,则余数为0;如果某一位出错,则余数不为0。不同的位数出错其余数不同,余数和出错位序号之间有唯一的对应关系。

总结:
在这里插入图片描述

嵌入式-芯片分类

主流嵌入式芯片分为DSP、Soc、MPU和MCU等。
如下图所示:
在这里插入图片描述

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

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

相关文章

STM32智能机器人控制系统教程

目录 引言环境准备智能机器人控制系统基础代码实现:实现智能机器人控制系统 4.1 数据采集模块 4.2 数据处理与控制模块 4.3 通信与导航系统实现 4.4 用户界面与数据可视化应用场景:机器人控制与优化问题解决方案与优化收尾与总结 1. 引言 智能机器人控…

js中的“?“/“??“以及“||“的详解(值得收藏)

前言 在JavaScript中,问号(?)通常用于三元运算符,而两个问号(??)则是空值合并运算符,用于在左侧操作数为null或undefined时,返回右侧的操作数。 1、?. (可选链运算符…

NCRE3 1-4 宽带接入技术的基本类型

提示,这一部分内容大多数是记的 xDSL数字用户线技术 分类 按照上行和下行的速率是否相同分类分为速率对称性,速率非对称性 相关缩写 ADSL( 非对称数字用户线) 利用普通电话业务(POTS)方式,提供告诉数字业务,允许保留已有的模拟电话业务的…

【c++】C++类和对象详解(下)

目录 思维导图大纲: const成员函数 取地址运算符重载 再探构造函数-初始化列表 隐式类型转换 c语言中我们了解: c中: 单参数 多参数 防止类型转换 static成员 友元 内部类 匿名对象 对象拷贝时的编译器优化 思维导图…

第11讲:变量的基本

变量的数据类型分为基本数据类型、行生数据类型还有POU实例名三种。 此处主要讨论一下基本数据类型。 基本数据类型的种类 基本数据类型的表示方法 1、布尔型、位串型、常数 2、整数型 (1)有符号整数型 SINT型,INT型,DINT型及LINT型,为有符号整数型,二进制表示的最高…

Aigtek:电压放大器的选型方法有哪些

电压放大器是电子电路中常见的元件,用于将输入电压信号放大到所需的水平。在选择适合特定应用的电压放大器时,需要考虑多个因素,包括性能要求、电源电压、带宽、噪声等。下面安泰电子将详细介绍电压放大器的选型方法,以帮助工程师…

【深入理解SpringCloud微服务】深入理解Eureka核心原理

深入理解Eureka核心原理 Eureka整体设计Eureka服务端启动Eureka三级缓存Eureka客户端启动 Eureka整体设计 Eureka是一个经典的注册中心,通过http接收客户端的服务发现和服务注册请求,使用内存注册表保存客户端注册上来的实例信息。 Eureka服务端接收的…

SQLite读取分析指南:新手也能轻松上手的实用教程

SQLite是一个轻量级的关系型数据库,目前已经更新到SQLite3版本。它不仅具有跨平台的特性而且占用的资源非常低,目标是设计来做嵌入式的。本教程将深入浅出地讲解图形化界面和python脚本来读取sqlite数据库这两种方法,从基础概念到实际应用,step by step地…

Windows定时任务实现关闭和开启声音

目录 1. 下载并放置 nircmd.exe1.1 下载 NirCmd:1.2 放置 nircmd.exe: 2. 定时关闭声音2.1 打开任务计划程序:2.2 创建基本任务:2.3 设置任务名称和描述:2.4 触发器:2.5 操作:2.6 设置程序或脚本…

新手小白的pytorch学习第十弹----多类别分类问题模型以及九、十弹的练习

目录 1 多类别分类模型1.1 创建数据1.2 创建模型1.3 模型传出的数据1.4 损失函数和优化器1.5 训练和测试1.6 衡量模型性能的指标 2 练习Exercise 之前我们已经学习了 二分类问题,二分类就像抛硬币正面和反面,只有两种情况。 这里我们要探讨一个 多类别…

专业护眼灯品牌有哪些?五款爆款护眼灯品牌推荐

在当今时代,电子设备在我们的日常生活中扮演着越来越重要的角色。然而,长时间使用这些设备可能会增加眼睛疲劳和近视的风险。为了解决这一问题,护眼台灯应运而生,并逐渐成为许多家庭和办公室的必需品。面对市场上琳琅满目的护眼台…

<数据集>苹果腐烂识别数据集<目标检测>

数据集格式:VOCYOLO格式 图片数量:978张 标注数量(xml文件个数):978 标注数量(txt文件个数):978 标注类别数:2 标注类别名称:[fresh_apple, rotten_apple] 序号类别名称图片数框数1fresh_apple520922…

排序算法与复杂度介绍

1. 排序算法 1.1 排序算法介绍 排序也成排序算法(Sort Algorithm),排序是将一组数据,依照指定的顺序进行排序的过程 1.2 排序的分类 1、内部排序: 指将需要处理的所有数据都加载到**内部存储器(内存&am…

【NLP自然语言处理】基于BERT实现文本情感分类

Bert概述 BERT(Bidirectional Encoder Representations from Transformers)是一种深度学习模型,用于自然语言处理(NLP)任务。BERT的核心是由一种强大的神经网络架构——Transformer驱动的。这种架构包含了一种称为自注…

MySQL_JDBC

目录 一、JDBC常用的接口和类 1.1 数据库连接 Connection 1.2 Statement 对象 二、JDBC的使用 总结 【Java 的数据库编程】 JDBC 即 Java Database Connectivity (Java数据库连接),是一种用于执行 SQL 语句的 Java API。这个 API 由 java.sql.*,javax.sql.* …

零基础学SpringBoot(一)--初识SpringBoot

1. SpringBoot简介 SpringBoot 是Spring家族中的一个全新的框架,它用来简化Spring应用程序的创建和开发过程,也可以说Spring Boot能简化我们之前采用SSM(SpringMVC Spring MyBatis)框架进行开发的过程。 以前我们采用SSM框架进行开发的时候&#xff0c…

算法017:二分查找

二分查找. - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/binary-search/ 二分查找,其实是双指针的一种特殊情况,但是时间复杂度极低&#…

python的csv库常用操作

csv 模块是 Python 标准库中的一个模块,用于处理 CSV(逗号分隔值)文件。它提供了简单易用的功能来读取和写入 CSV 文件。以下是一些常用的操作: 一、读取 CSV 文件 新建文件data.csv,内容如下: 使用 csv.…

使用JAVA代码实现生成二维码

系列文章目录 1.SpringBoot整合RabbitMQ并实现消息发送与接收 2. 解析JSON格式参数 & 修改对象的key 3. VUE整合Echarts实现简单的数据可视化 4. List<HashMap<String,String>>实现自定义字符串排序(key排序、Val…

录屏神器!这四款软件让你轻松记录屏幕

随着现在在线教育的兴起,用录屏软件将课程录制下来能够帮助我助我们通过视频分享知识,展示成果。电脑怎么录屏的重要性愈发凸显了,下面我为你介绍几款热门的 录屏软件吧。 1.福晰REC大师 这个软件是我用过觉得最顺手的一款了。它录制的视频…