计算机组成原理——基础入门总结(一)

news2025/1/13 15:57:16

本帖更新一些关于计算机组成原理的重点内容。由于博主考研时并不会考这门课,但是考虑到操作系统中又很多重要晦涩的概念涉及很多诸如内存、存储器、磁盘、cpu乃至各种寄存器的知识,此处挑选一些核心的内容总结复盘一遍——实现声明:本帖的内容注重知识扩展,而非纯应试~

配套课程:王道考研


一.计算机的发展

计算机系统=硬件+软件(硬件决定了性能天花板,而软件又决定了能将性能发挥到什么程度~)

计算机在处理数字计算时,本质上是在处理一系列电信号,逻辑原件是处理电信号的最小单元

发展历史:

  • 1946年:埃尼亚克(ENIAC)——因为军事应运而生(电子管时代1946-1957)
  • 晶体管时代(1958-1964):体积、功耗降低;出现面向过程的程序设计语言;操作系统的雏形出现
  • 中小规模集成电路时代(1965-1971):规模进一步缩小,可靠性进一步提高,各种高级语言发展迅速,开始出现分时操作系统
  • 超大规模集成电路时代(1971-至今):出现微处理机(CPU)以及个人计算机(PC),同时出现Windows等各种耳熟能详的操作系统

自从奔腾系列开始,CPU基本上进入64位的字长~

 

 

 java与Python等语言是更适合于网络环境的编程语言。

二.计算机硬件的基本组成

 为了解决ENIAC需要手动接线的弊端,冯诺依曼第一次提出了存储程序的概念!

 本质在于——解决了手动操作的缺点。

 如上是冯诺依曼体系结构。

(所谓软件与硬件在逻辑上等价,要联想OS中临界区用软件和硬件实现互斥的两种对立情况!)

特点:

1.计算器由五大部件组成

2.指令和数据以同等地位存放于存储器, 可按地址寻访

3.指令和数据用二进制码表示

4.指令由操作码和地址码组成

5.出现存储程序

6.以运算器为核心!

进化:现代计算机以存储器为核心!

而当大规模集成电路出现后, 运算器和控制器往往集成在一个芯片上

而这个芯片就是常说的——CPU

注意:主存即所谓的内存~ 

而辅存(存储、磁盘),本质上应该归结为IO设备~

三.硬件工作原理

1.主存储器

存储字长通常情况下为8个bit的整数倍~

存储元的实现细节本质上是依靠电容实现的。

  • MAR位数决定存储体的个数
  • MDR的位数决定存储单元的存储字长

易混淆:

  • 字节:Byte,即1Byte=8bit(1字节对应8比特)
  • 字:每个存储单元可以存放比特的位数——即存储字长,大小由寄存器本身决定

注意:ISP(运营商)所提供的100兆宽带,单位是100Mbps,其中的b象征的是bit而并非字节,换算下来将近12.5MB每秒,结合计网的知识,带宽只是理想状态下的网速,因此假使办理的宽带为所谓的1000兆,实际上的最高网速也只有125MB/s,而在实际使用时,可能达到20MB已经是最大值了~

 2.运算器

核心在于ALU——算术逻辑单元,造价很高。

 3.控制器

核心在于CU。

 

 高级语言代码的执行原理均为一连串的二进制码组成(机器指令)。

如上图,解下来通俗地描述一下CPU实现a=2赋值这一过程的背后原理:

  1. 首先,程序计数器PC指向下标为0的第一条指令,因此根据序号下标来寻找这条指令的内容,即把存储地址发送给MAR。
  2. 然后MAR根据给出的地址,去存储体中找到完整的指令内容
  3. 存储体将指令送给MDR
  4. MDR再将指令传送给指令寄存器IR
  5. IR将指令的操作码部分传递给CU,即指明了该条指令需要实现什么样的功能
  6. IR再将指令的地址码传给MAR,即寻找该条指令所需要的数据所对应的地址!
  7. 以此类推第2步
  8. 以此类推第3步
  9. MDR将数据传送给ACC,即累加器

指令完成后,PC实现自加1。

而当运行到停机指令时,这时操作系统需要通过中断处理或者系统调用来终结当前进程的执行~

 四.系统层次结构

下层是上层的基础,上层是下层的扩展~

  • 编译型语言:将编写的源程序全部语句一次性全部翻译为机器语言程序,而后再执行机器语言程序(只需要翻译一次)——(exe文件的产生可以为一种理解)
  • 解释型语言: 将源程序的语句逐行翻译,翻译结束后就立即执行,紧接着再翻译下一句

五.性能指标

 1.总容量

 

2.CPU性能主频 

主频越高的CPU速度越快

CPI:执行一条指令需要的时钟周期

(具体时间与其他因素有关)

平均执行一条指令的耗时:CPI*CPU时钟周期

(频率类的信息,G代表10的9次方)

 3.其他:

 4.基准程序(某种跑分软件......)

通过设计好的程序代码,测试当前CPU执行目标代码所需要的时间。

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

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

相关文章

【CCF】第30次csp认证——202305-1重复局面

202305-1重复局面: 问题描述 国际象棋每一个局面可以用大小为 88 的字符数组来表示,其中每一位对应棋盘上的一个格子。六种棋子王、后、车、象、马、兵分别用字母 k、q、r、b、n、p 表示,其中大写字母对应白方、小写字母对应黑方。棋盘上无…

[ESP32 IDF+Vscode]蓝牙配网后采用上传温湿度数据至阿里云(MQTT协议)

阿里云平台的设置 参考文章: http://t.csdn.cn/RzLGqhttp://t.csdn.cn/RzLGq Blufi配网 1.简介 BluFi 是一款基于蓝牙通道的 Wi-Fi 网络配置功能,适用于 ESP32。它通过安全协议将 Wi-Fi 配置和证书传输到 ESP32,然后 ESP32 可基于这些信…

OpenGL超级宝典(第五版)疑难点汇总解析

《OpenGL超级宝典(第五版)》如下: 1. 在该书的第1章的Block例子中用到了平面阴影投射矩阵,关于该矩阵的推导,参见: OpenGL: 平面阴影投射矩阵的推导 2. 在该书的第8章的pix_buffs例子中用到了正交投影矩阵的推导过程…

腾讯mini项目-【指标监控服务重构】2023-08-23

今日已办 进度和问题汇总 请求合并 feature/venus tracefeature/venus metricfeature/profile-otel-baserunner-stylebugfix/profile-logger-Syncfeature/profile_otelclient_enable_config 完成otel 开关 trace-采样metrice-reader 已经都在各自服务器运行,并接入…

Datagrip 下载、安装教程,详细图文,亲测有效

文章目录 前言1. 下载2. 安装3 DataGrip 常用操作4 推荐阅读 前言 DataGrip 是 JetBrains 发布的多引擎数据库环境,支持 MySQL 和 PostgreSQL,Microsoft SQL Server 和 Oracle,Sybase,DB2,SQLite,还有 Hyp…

RocketMQ快速实战以及集群架构详解

文章目录 1、MQ简介1.1 、定义1.2 、作用 2、RocketMQ产品特点2.1、RocketMQ介绍2.2 、RocketMQ特点 1、MQ简介 1.1 、定义 ​ MQ:MessageQueue,消息队列。是在互联网中使用非常广泛的一系列服务中间件。 这个词可以分两个部分来看 一是Message&#…

SmartApi使用说明

缘起: 搞移动开发十多年了,接口、数据、数据模型、以及数据边界值的处理是需要团队协作解决,而这方面恰恰是总容易导致bug难修复的地方。而一款好用的api调试工具对于后端、前端、测试都是必须必的掌握熟练使用,Api就像人体的血管…

开发、测试、生产环境

开发环境(Development Environment): 开发环境是用于开发新功能、修改和调试代码的环境。 在开发环境中,开发人员可以针对特定需求编写和测试代码。 通常,开发环境会模拟完整的系统环境,并提供开发人员所需…

SQL 性能优化总结

文章目录 一、性能优化策略二、索引创建规则三、查询优化总结 一、性能优化策略 1. SQL 语句中 IN 包含的值不应过多 MySQL 将 IN中的常量全部存储在一个排好序的数组里面,但是如果数值较多,产生的消耗也是比较大的。所以对于连续的数值,能用…

手撕排序之堆排序

一、概念: 什么是逻辑结构、物理结构? 逻辑结构:是我们自己想象出来的,就像内存中不存在一个真正的树 物理结构(存储结构):实际上在内存中存储的形式。 堆的逻辑结构是一颗完全二叉树 堆的物理结构是一个数组 之…

常见请求方法

请求方法的本质 请求方法是请求行中的第一个单词,它向服务器描述了客户端发出请求的动作类型。在 HTTP 协议中,不同的请求方法只是包含了不同的语义,但服务器和浏览器的一些约定俗成的行为造成了它们具体的区别 fetch(https://www.baidu.com…

【算法|双指针|链表】反转链表

Leetcode206 反转链表 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 示例 1: 输入:head [1,2,3,4,5] 输出:[5,4,3,2,1]示例 2: 输入:head [1,2] 输出:[2,1]示例…

opencv 处理扫描件移除灰色背景图

先看对比效果: 再上代码: import cv2 import numpy as npdef remove_gray_background(input_image_path, output_image_path, threshold180):# Load the input imageimage cv2.imread(input_image_path)# Convert the image to grayscalegray cv2.cvtColor(image, cv2.COLO…

【数据可视化】动态条形图Python代码实现

使用 Python 中的 bar_chart_race_cn 库创建动态条形图 前言 数据可视化在今天的数据分析和传达信息中起着至关重要的作用。动态条形图是一种强大的数据可视化工具,可以帮助我们展示随时间变化的数据趋势。本文将介绍如何使用 Python 编程语言中的 bar_chart_race…

阿里云yum源和tuna源

阿里云开源镜像站地址:阿里巴巴开源镜像站-OPSX镜像站-阿里云开发者社区阿里巴巴开源镜像站,免费提供Linux镜像下载服务,拥有Ubuntu、CentOS、Deepin、MongoDB、Apache、Maven、Composer等多种开源软件镜像源,此外还提供域名解析D…

背包问题学习笔记-01背包

背景 背包问题是动态规划问题中的一个大类,学习背包问题对于掌握动态规划十分重要。背包问题也很容易成为程序员算法面试中的一个槛,但其实背包问题已经被研究,讲解的比较成熟了,在这些丰富的讲解资料的基础之上,大家…

图注意网络(GAT)的可视化实现详解

能够可视化的查看对于理解图神经网络(gnn)越来越重要,所以在这篇文章中,我将介绍传统GNN层的实现,然后展示ICLR论文“图注意力网络”中对传统GNN层的改进。 假设我们有一个表示为有向无环图(DAG)的文本文档图。文档0与文档1、2和3有一条边&am…

第72步 时间序列建模实战:单步滚动预测(以决策树回归为例)

基于WIN10的64位系统演示 一、写在前面 从这一期开始,我们开始基于python构建各种机器学习和深度学习的时间序列预测模型,本质上就是调用各种模型的回归分析的属性。所以很多模型其实之前都介绍过,比如说决策树、SVM等等。 同样&#xff0…

【踩坑篇】代码中使用 Long 作为 Map的Key存在的问题

本周的工作结束&#xff0c;详述一些在项目代码中实际遇到的一些坑。 代码中遇到这样一个场景&#xff1a; 有个业务接口&#xff0c;接口返回的值是一个JSON格式的字符串&#xff0c;通过JSON解析的方式&#xff0c;解析为格式为&#xff1a; Map<Long, Map<String, O…

数据结构——时间复杂度与空间复杂度

目录 一.什么是空间复杂度与时间复杂度 1.1算法效率 1.2时间复杂度的概念 1.3空间复杂度的概念 二.如何计算常见算法的时间复杂度 2.1大O的渐近表示法 使用规则 三.如何计算常见算法的空间复杂度 3.1 大O渐近表示法 3.2 面试题——消失的数字 3.3 面试题——旋转数组 一…