计算机里基本硬件的组成以及硬件协同

news2025/1/18 11:53:00

文章目录

    • 冯·诺依曼体系
    • 输入设备
    • 输出设备
    • 存储器
    • 运算器
    • 控制器
    • 协同工作的流程

冯·诺依曼体系

世界上第一台通用计算机,ENIAC,于1946年诞生于美国一所大学。
ENIAC研发的前期,需要工作人员根据提前设计好的指令手动接线,以这种方式输入指令给计算机。显然,这种方式程序运行的效率受人工的影响,大部分时间消耗在人工手动接线上面。

ENIAC研发的中期,冯诺依曼加入研发小组。此后,三位大佬(包括冯诺依曼在内)基于对ENIAC的改进,研发了EDVAC机,冯诺依曼在研发EDVAC机时提出了“存储程序”的思想, 奠定了现代计算机的基本结构。

存储程序:将事先编制好的程序和数据送入主存才能执行,一旦程序被启动执行,就无需操作人员的干预,计算机会自动逐条执行指令,直至程序执行结束

这个时候就不需要人工手动接线输入指令了,从而提升了效率。以这种概念为基础的计算机我们把它叫做冯·诺依曼机。冯·诺依曼体系结构如下图:
在这里插入图片描述
其特点

  1. 采用“存储程序”的方式
  2. 计算机硬件系统由运算器、控制器、存储器(主、外)、输入设备、输出设备五大部件组成
  3. 指令和数据以同等地位保存在存储器里,均用二进制表示,计算机可以区分。
  4. 指令由操作码地址码组成,操作码指出操作的类型,地址码指出操作数的地址。

输入设备

输入设备的任务:用来接收原始内容,然后把程序和数据转换为计算机能够接受和识别的形式输入计算机。

例如:

  • 键盘
  • 鼠标

输出设备

输出设备的任务:将计算机内经过计算机处理的结果转换为我们能看懂的形式输出。

例如:

  • 显示屏
  • 打印机

存储器

存储器分为主存储器辅助存储器,主存储器又可以叫做内存储器,也就是我们平时经常提到的内存。主存储器 + CPU就构成了主机,和我们小时候提到的主机是不一样的。辅助存储器又可以叫做外存储器,磁盘是最常见的外存储器。
在这里插入图片描述

主存储器我们可以把它想象成一个非常大的中药柜子 + 取药、放药的柜台
在这里插入图片描述
主存储器的存储体 相当于 这个大中药柜子。
存储体由许多存储单元组成,存储单元相当于中药柜子里的一个个小柜子。
存储单元包含若干存储元件,每个存储元件存储一个二进制位。相当于一个小柜子里有若干的空间,每一个空间可以放一个草药(我把它抽象过度了🤗)

一个存储单元里可以放一串二进制代码,这串代码我们呢把它叫做存储字,这串代码的位数为存储字长。存储字长就相当于小柜子里放了多少个草药。存储字长, 一个字只能是1字节,或者1字节的偶数倍

现在来模拟主存储器的工作方式:
取数据的过程:

  • CPU把它需要的数据地址,放到地址寄存器MAR里面。
  • 主存储器根据地址寄存器里面的地址,去存储体内找数据
  • 主存储器将数据,存入数据寄存器MDR,等待CPU来获取。

存数据的过程

  • CPU把要存入的数据,放到数据寄存器MDR里
  • CPU把地址(它想把数据放在哪一个位置的地址),放入地址寄存器MAR
  • 主存储器根据地址寄存器MAR里的地址,将数据寄存器MDR里的数据放入存储体。

主存储器存取数据的方式,很容易联想到实际例子。
在这里插入图片描述
以中医师徒为例,类比主存储器取数据的过程。徒弟负责打杂,例如师傅想要柜子里的草药—党参,师傅就把党参的位置写在纸条上,然后徒弟根据纸条上的位置,去柜子里找,找到了就把党参放在柜台上,等待师傅拿就可以了。

现代计算机,地址寄存器MAR和数据寄存器MDR是放在CPU里面的。


CPU中的运算器和控制器,在"运算器"和"控制器"里并不讲解它们的工作原理,只介绍它们的基本部件,工作原理在“工作流程”中结合进行介绍。

运算器

运算器是用来进行算术运算和逻辑运算的。
在这里插入图片描述
算术运算,例如加、减、乘、除
逻辑运算,例如

  • 异或
  • 移位

运算器的核心是算术逻辑单元,简称ALU。运算器里面有三个寄存器是必须存在的,分别是累加器ACC、乘商寄存器MQ和通用的操作数寄存器X。用于暂时存放操作数和中间结果。

  • 累加器ACC。存放操作数和运算结果
  • 乘商寄存器MQ。在乘、除运算时,存放操作数和运算结果
  • 操作数寄存器X。通用的操作数寄存器,存放操作数和运算结果。

控制器

控制器相当于指挥中心。
在这里插入图片描述
程序计数器PC,存放当前想要执行的指令的地址。具备自动加1的功能,当PC里面的指令被取出来以后,PC里放下一条将要执行指令的地址。

指令寄存器IR,当PC把地址放到地址寄存器MAR里,主存储器就把该地址上的指令取出,放到数据寄存器MDR里,指令寄存器IR的内容来自MDR放的是当前的指令。

指令由操作码和地址码组成,指令寄存器IR里的指令,的操作码,被送入控制单元CU用于分析指令并发出命令;而指令的地址码又被送入地址寄存器MAR里,用于取操作数的数据。
在这里插入图片描述
指令和数据在指令周期的不同阶段,所以CPU能够区分指令和数据。


协同工作的流程

#include <iostream>
int main(void){
	int a = 2, b = 3, c = 1, y = 0;
	y = a * b + c;
	return 0;
}

上述文件经历预处理编译汇编链接四个大步骤,最终形成一个可执行文件。汇编阶段,汇编器会把程序翻译成机器语言指令,也就是二进制代码。可执行文件里的内容就是由上述步骤转化而来的二进制。


现在以该可执行文件演绎一部分过程。要执行该文件时,先将它的代码和数据加载到内存里面,并且把第一条指令的地址写入程序计数器PC中
在这里插入图片描述
第一条指令周期:
(1)(PC)->MAR 。PC程序计数器里的地址通过地址总线,输入到地址寄存器MAR里,主存储器收到CPU发送的读信号
(2)M(MDR)->MDR。从存储体内拿到指令, 放入数据寄存器MDR。此时MDR里的数据为000001 0000000101
(3)MDR->IR。将MDR里的指令通过数据总线给指令寄存器,IR = 000001 0000000101,指令由操作码和地址码组成。
(4)OP(IR)。IR里的指令,的操作码给控制单元CU,CU对操作码分析,得到这是一个取数指令
(5)AD(IR)。IR里的指令,的地址码继续给地址寄存器MAR,(MAR) = 5;
(6)主存储器根据地址码为5,去5地址取出数据,MDR = 0000000000000010 = 2
(7)将MDR里的数据,放入运算器里的累加器ACC = 2

(1)~(3)是取指令,取完指令后,程序计数器PC自动+1,现在PC里面保存的是地址1
(4)分析指令
(5)~(7)执行取数指令。

第二条指令周期:
(1)将程序计数器PC里的指令地址,通过地址总线,送入地址寄存器MAR内, (MAR)= 1
(2)主存储器根据地址找到指令,将指令放到数据寄存器MDR,此时MDR = 000100 0000000110
(3)将MDR里的指令,通过数据总线,送入指令寄存器IR,IR = 000100 0000000110
(4)IR内,指令的操作码送入控制单元CU,CU分析指令,这是 “乘法”指令
(5)IR内,指令的地址码送入地址寄存器MAR,此时(MAR)= 0000000110 = 6
(6)主存储器取出地址为6的数据0000000000000011 ,(MDR) = 0000000000000011 = 3
(7)将数据寄存器MDR里的数据,通过数据总线,送入运算器里的乘商寄存器MQ里, 此时(MQ) = 0000000000000011 = 3
(8)累加器ACC里的数据放入通用的操作数寄存器X里面。此时(x) = 2
(9)由算术逻辑单元ALU执行乘法运算,得到6,放入累加器ACC里面,此时(ACC)=6,如果乘积太大,就需要乘商寄存器MQ来辅助。

第三条指令周期:



综上,CPU工作的流程就是:取指令 ===>> 分析指令 ===>>执行指令。这种方式叫做流水线。还有一种机制比流水线要好得多,叫做超标量CPU。你可以这样理解,就是设计了一种机制,使得CPU的工作“超标量”了,把超标量理解为生活上的超标量就行。那么这种让CPU超标量的机制是如何的呢?
在这里插入图片描述
这种设计中,多了一个保持缓冲区。把多个指令同时取出并进行解码,放入保持缓冲区内,如果执行单元有“在偷懒的”(保持缓冲区内还有可处理的指令,但是执行单元有空闲),就从保持缓冲区取出并且执行。缺点在于:从保持缓冲区取出的指令,极大可能不按原来的顺序执行,这个应该比较好理解。

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

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

相关文章

卸载大脑,相信DFS

切莫相信动规&#xff0c;吾将为您指明前进之路 印子 比赛时&#xff0c;你是否有这样的经历&#xff1a;不敢用for暴搜&#xff0c;又不会用数学公式推理&#xff1b;焦急地在纸上打草&#xff0c;却没有优化思路&#xff1b;明明比赛前一天晚上背了那么多模板却脑子一片空白…

Modbus tcp转ETHERCAT网关modbus tcp/ip协议

捷米JM-ECT-TCP网关能够连接到Modbus tcp总线和ETHERCAT总线中&#xff0c;实现两种不同协议设备之间的通讯。这个网关能够大大提高工业生产的效率和生产效益&#xff0c;让生产变得更加智能化。捷米JM-ECT-TCP 是自主研发的一款 ETHERCAT 从站功能的通讯网关。该产品主要功能是…

《Deep Leakage from Gradients》

Deep Leakage from Gradients 摘要 现在的分布式机器学习&#xff0c;或联邦学习中最常用的一种方法就是交换梯度&#xff0c;长期以来人们都认为交换梯度的安全的&#xff0c;但是本文提出从公开共享的梯度中获得私有训练数据是可能的。文章将这种泄漏命名为Deep leak from …

PDPS教程:导出带颜色的JT格式2D布局图文件的另一种方法

目录 概述 布局图平面化与边缘化处理 导出为JT格式文件 JT格式文件查看 概述 在PDPS软件中导入机器人生产线或工作站2D布局图之前&#xff0c;要先将布局图文件转换为JT格式。 使用Crossmanager软件转换出来的2D布局图文件会将图形元素原有的颜色自动修改为黑白颜色&…

源码学习初章-基础知识储备

文章目录 学前准备源码地址引言extern "C" 宏定义平台宏跨平台宏vstdio平台禁用警告宏 连接、双层宏定义函数宏系统函数宏自定义函数宏多语句执行宏do while0 普通宏定义 C的一些必备函数知识回调函数和函数指针回调函数wireshark-4.0.7源码例子函数指针wireshark4.0…

Flutter-基础Widget

Flutter页面-基础Widget 文章目录 Flutter页面-基础WidgetWidgetStateless WidgetStateful WidgetState生命周期 基础widget文本显示TextRichTextDefaultTextStyle 图片显示FlutterLogoIconImageIamge.assetImage.fileImage.networkImage.memory CircleAvatarFadeInImage 按钮R…

视频号私信关注引流脚本实操演示教学,分享几个微信视频号引流推广的方法

大家好&#xff0c;我是小刘互联网思维。最近视频号越来越火&#xff0c;所以很多人或者小团队也都盯上了这个新兴市场。有人选择手动引流&#xff0c;就一定有人想软件引流&#xff0c;有些朋友就私信问我这个软件引流要怎么操作&#xff0c;接下来我就为大家简单讲解视频号脚…

【数据结构】【王道408】——PPT截图与思维导图

自用视频PPT截图 视频网址王道B站链接 23考研 408新增考点&#xff1a; 并查集&#xff0c;红黑树 2023年408真题数据结构篇 408考纲解读 考纲变化 目录 第一章 绪论第二章 线性表顺序表单链表双链表循环链表静态链表差别 第三章 栈 队列 数组栈队列栈的应用数组 第四章 串第五…

RustDesk 1.2 现已发布

RustDesk 1.2 现已发布&#xff0c;此版本采用 Flutter 重写桌面版本&#xff0c;支持 Wayland 被控。 一些值得关注的变化有&#xff1a; 用 Flutter 重写支持 ipv6&#xff08;Beta&#xff09;增加一次性密码QuickSupport &#xff08;Beta&#xff09;硬件编解码器 H264 /…

支持向量机(iris)

代码&#xff1a; import pandas as pd from sklearn.preprocessing import StandardScaler from sklearn import svm import numpy as np# 定义每一列的属性 colnames [sepal-length, sepal-width, petal-length, petal-width, class] # 读取数据 iris pd.read_csv(data\\i…

MicroPython动手做(14)——掌控板之OLED屏幕

知识点&#xff1a;什么是掌控板&#xff1f; 掌控板是一块普及STEAM创客教育、人工智能教育、机器人编程教育的开源智能硬件。它集成ESP-32高性能双核芯片&#xff0c;支持WiFi和蓝牙双模通信&#xff0c;可作为物联网节点&#xff0c;实现物联网应用。同时掌控板上集成了OLED…

win10安装vs6行号插件

插件包名&#xff1a;win10 VC6LineNumberAddin 下载包&#xff1a; 链接: https://pan.baidu.com/s/13T-NAxQQDcA_K1hHJQ0vWw?pwdbe3r 提取码: be3r 修改reg为以下&#xff1a; Windows Registry Editor Version 5.00 [HKEY_LOCAL_MACHINE\SOFTWARE\DavidHowe Software\Lie…

想要零起步做跨境电商,可以试试这7个步骤!

近几年&#xff0c;跨境电商行业在不断的高速发展。国家政策的支持&#xff0c;行业的迅猛发展&#xff0c;使得跨境电商成为我国经济发展中的一匹黑马&#xff0c;不仅业务呈爆发式增长&#xff0c;我国跨境电商也逐步实现了“买全球卖全球”的愿望。 想要零起步做跨境电商&a…

linux学习(gbd进程)[5]

gdb set var i n #可设置变量值进程 冯诺依曼结构

LabVIEW使用灰度和边缘检测进行视频滤波

LabVIEW使用灰度和边缘检测进行视频滤波 数字图像处理&#xff08;DIP&#xff09;是真实和连续世界的离散表示。除此之外&#xff0c;这种数字图像在通信、医学、遥感、地震学、工业自动化、机器人、航空航天和教育等领域变得非常重要。计算机技术越来越需要视频图像的数字图…

一文讲解开发中的命名规范

命名规范 好的代码本身就是注释, 所以我们需要统一命名风格。 ​ 在本文中&#xff0c;将从大到小&#xff0c;从外到内&#xff0c;总结Java编程中的命名规范。文中将会涉及到日常工作中常见的命名示例&#xff0c;如包命名&#xff0c;类命名&#xff0c;接口命名&#xff0c…

java+springboot+mysql智慧办公OA管理系统

项目介绍&#xff1a; 使用javaspringbootmysql开发的智慧办公OA管理系统&#xff0c;系统包含超级管理员&#xff0c;系统管理员、员工角色&#xff0c;功能如下&#xff1a; 超级管理员&#xff1a;管理员管理&#xff1b;部门管理&#xff1b;职位管理&#xff1b;员工管理…

传输层中一些零碎且易忘的知识点

端口号&#xff1a;共两个字节 不同类型的端口号&#xff1a; 服务端端口号 熟知端口号&#xff1a;0&#xff5e;1023登记端口号&#xff1a;1024&#xff5e;49151 客户端使用端口号&#xff08;短暂/临时端口号&#xff09;&#xff1a;49152&#xff5e;65535 要记得常见应…

Linux之Shell 编程详解(一)

第 1 章 Shell 概述 1&#xff09;Linux 提供的 Shell 解析器有 [atguiguhadoop101 ~]$ cat /etc/shells /bin/sh /bin/bash /usr/bin/sh /usr/bin/bash /bin/tcsh /bin/csh2&#xff09;bash 和 sh 的关系 [atguiguhadoop101 bin]$ ll | grep bash -rwxr-xr-x. 1 root root …

EIP-2535 Diamond standard 实用工具分享

前段时间工作对接到了这标准的协议&#xff0c;于是简单介绍下这个标准分享下方便前端er使用的调用工具 一、标准的诞生 在写复杂逻辑的solidity智能合约时&#xff0c;经常会碰到两个问题&#xff0c;升级和合约大小限制。 升级目前有几种proxy模式&#xff0c;通过delegateca…