当前位置: 首页 > news >正文

计算机组成原理笔记-第1章 计算机系统概论

第一章 计算机系统概论

笔记PDF版本已上传至Github个人仓库:CourseNotes,欢迎fork和star,拥抱开源,一起完善。

该笔记是最初是没打算发网上的,所以很多地方都为了自我阅读方便,我理解了的地方就少有解释;我不理解的地方理解后加上的解释便很多。

因此,若读者在阅读过程中遇到错误或理解问题,请评论区留言或者私信,我们一起讨论:看到会及时回复。

1.1 计算机系统简介

  • 计算机系统组成
    • 硬件:计算机的实体,如主机、外设等
    • 软件:由具有各类特殊功能的信息(程序)组成,分为应用软件,系统软件
  • 计算机体系结构和计算机组成的区别
    • 计算机体系结构研究的是程序员所见到的计算机系统的属性概念性的结构与功能特性,具体来说就是指令系统、数据类型、寻址技术、I/O 机理
    • 计算机组成研究的是如何实现计算机体系结构所体现的属性,例如如何实现乘法指令

1.2 计算机系统基本组成

1.2.1 基本概念
  • 冯诺依曼计算机的特点
    • 计算机5部分组成
    • 指令和数据具有同等地位,按照地址寻访
    • 指令和数据用二进制表示
    • 指令由操作码地址码组成
    • 存储程序
    • 运算器为中心

  • 现代计算机硬件框图

1.2.2 五大部件的基本组成

  • 存储器的基本组成
    • 存储体:由若干个存储单元构成
    • 存储单元:也叫存储存放一串二进制代码,每个存储单元赋予一个地址号,按地址寻访
    • 存储字:存储单元中二进制代码的组合,和存储单元意思相近
    • 存储字长:存储单元中二进制代码的位数存储字长:存储单元中二进制代码的位数,按字编址时,机器字长=存储字长。假如按字节编址,存储器一个存储单元大小为1个字节。现在的计算机都是按字节编址了。
    • 主存地址寄存器(MAR):连接地址总线,可以反映存储单元的个数
    • 主存数据寄存器(MDR):连接数据总线,可以反映存储字长
      • 例:MAR=4,MDR=8,则由 2 4 = 8 2^4=8 24=8个存储单元,每个存储单元可以存储8个数,因此存储体容量为 8 × 8 = 64 8\times8=64 8×8=64
  • 运算器的基本组成

    • ALU(Arithmetic&logical Unit)算术逻辑单元是能实现多组算术运算和逻辑运算的组合逻辑电路。ALU是组合逻辑电路,要保存就需要用到时序逻辑电路
    • ACC(Accumulator)累加寄存器,专门用来存放操作数或运算结果。两个操作数中的指令的通常一个操作数在累加器A中,运算完成后累加器A中便可得到运算结果。
    • MQ(Multiple—Quotient Register)乘商寄存器。主要负责数据的乘法与除法运算并可保存运算结果
  • 控制器的基本组成

    • PC(Program Counter)程序计数器,存放当前欲执行指令在存储器的存放位置
    • IR(Instruction Register)指令寄存器,用来存放指令的,存放当前正在执行的指令,包括指令的操作码,操作数
    • CU(Control Unit)控制单元,是整个控制器的核心,分析指令,然后发出各种控制信号
1.2.3 指令的执行过程

  • 取指令(1、2、3 、4): PC MAR M MDR IR ,(PC)+1 PC
  • 分析指令 (5):OP(IR) CU
  • 执行指令 (6、7、8、9)Ad(IR) MAR M MDR ACC

1.3 计算机硬件的主要技术指标

  • 机器字长:机器字长是指 CPU一次能处理数据的位数,通常与 CPU 的寄存器位数有关。

  • 存储容量:存储器的容量应该包括主存容量辅存容量

  • 主存容量:指主存中存放二进制代码的总位数,定义为【存储容量=存储单元个数X存储字长】,例如,MAR=16,MDR=32,则【存储容量= 2 16 × 32 = 2 21 2^{16}\times32=2^{21} 216×32=221位】

    • 辅存容量:辅存容量通常用字节数来表示,如硬盘有80G( 1 G = 1024 M = 2 10 × 2 20 = 2 30 1G=1024M=2^{10}\times2^{20}=2^{30} 1G=1024M=210×220=230Byte)容量
    • 区别:是否为易失性存储器。
  • MIPS (Million Instructions Per Second):每秒钟CPU能执行的指令总条数 (单位:百万条/秒)。
    M I P S = Instruction count Execution time × 1 0 6 \mathrm{MIPS}=\frac{\text{Instruction count}}{\text{Execution time}\times10^6} MIPS=Execution time×106Instruction count

  • CPI(Cycle Per Instruction):执行一条指令所需时钟周期数。

  • FLOPS(Floating Point Operation Per Second):每秒浮点运算次数

相关文章:

  • 大疆无人机航点飞行KMZ文件提取航点坐标
  • 保存和调取得分的简易方法
  • Github 2024-06-19 C开源项目日报 Top9
  • C#面: 能够将非静态的方法覆写成静态方法吗?
  • Jenkins macos 下 failed to create dmg 操作不被允许hdiutil: create failed - 操作不被允许?
  • 使用Redis优化Java应用的性能
  • 如何将 ChatGPT 集成到你的应用中
  • lua中的lfs库介绍
  • vm.max_map_count是什么?起到什么作用
  • 剖析 Kafka 消息丢失的原因
  • MySQL中的客户端选项(三)
  • 【一步一步了解Java系列】:认识异常类
  • Redis学习|Redis 是什么、Redis 能干嘛、Window安装Redis、Linux下安装Redis、Redis测试性能
  • 2023-2024山东大学移动互联网开发期末回忆
  • 6.22面试问题【1】长链表排序选择归并还是快排
  • .pyc 想到的一些问题
  • 【技术性】Search知识
  • 30天自制操作系统-2
  • canvas实际项目操作,包含:线条,圆形,扇形,图片绘制,图片圆角遮罩,矩形,弧形文字...
  • C语言笔记(第一章:C语言编程)
  • emacs初体验
  • iOS | NSProxy
  • Magento 1.x 中文订单打印乱码
  • Python语法速览与机器学习开发环境搭建
  • SpiderData 2019年2月16日 DApp数据排行榜
  • 百度贴吧爬虫node+vue baidu_tieba_crawler
  • 前端学习笔记之观察者模式
  • 前端之Sass/Scss实战笔记
  • 原生 js 实现移动端 Touch 滑动反弹
  • 自制字幕遮挡器
  • 第二十章:异步和文件I/O.(二十三)
  • ​queue --- 一个同步的队列类​
  • #162 (Div. 2)
  • #Linux杂记--将Python3的源码编译为.so文件方法与Linux环境下的交叉编译方法
  • #pragma once
  • #pragma once与条件编译
  • (1)(1.13) SiK无线电高级配置(五)
  • (2)空速传感器
  • (4.10~4.16)
  • (7)svelte 教程: Props(属性)
  • (js)循环条件满足时终止循环
  • (Note)C++中的继承方式
  • (机器学习的矩阵)(向量、矩阵与多元线性回归)
  • (论文阅读23/100)Hierarchical Convolutional Features for Visual Tracking
  • (面试必看!)锁策略
  • (三十)Flask之wtforms库【剖析源码上篇】
  • (转)AS3正则:元子符,元序列,标志,数量表达符
  • (转)Sql Server 保留几位小数的两种做法
  • (轉貼) UML中文FAQ (OO) (UML)
  • (自用)gtest单元测试
  • *2 echo、printf、mkdir命令的应用
  • .a文件和.so文件
  • .NET Framework 服务实现监控可观测性最佳实践
  • .NET 将混合了多个不同平台(Windows Mac Linux)的文件 目录的路径格式化成同一个平台下的路径
  • .NET平台开源项目速览(15)文档数据库RavenDB-介绍与初体验