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

news/2024/9/28 20:58:10 标签: 硬件工程

第一章 计算机系统概论

笔记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):每秒浮点运算次数


http://www.niftyadmin.cn/n/5532509.html

相关文章

程序代码中的常见命名缩写

以下是一些程序代码中的常见命名缩写,尽量遵循清晰的格式: A-B adm:Administrator,管理员addr:Address,地址app:Application,应用程序arr:Array,数组avg&am…

深入理解适配器模式:Java实现与框架应用

适配器模式是一种结构型设计模式,它允许将一个类的接口转换成客户端希望的另一个接口。适配器模式使得原本由于接口不兼容而不能一起工作的类可以协同工作。在本篇博客中,我们将详细介绍适配器模式,并演示如何在Java中实现它。最后&#xff0…

学习C++第一天

1.命名空间 使用命名空间的目的是对标识符的名称进行本地化&#xff0c; 以避免命名冲突或名字污染&#xff0c;namespace关键字的出现就是针对这种问题的。 示例1&#xff1a; #include<stdio.h> #include<stdlib.h> int rand 10; int main() {printf("%…

【区分vue2和vue3下的element UI Descriptions 描述列表组件,分别详细介绍属性,事件,方法如何使用,并举例】

在 Element UI&#xff08;为 Vue 2 设计&#xff09;和 Element Plus&#xff08;为 Vue 3 设计&#xff09;中&#xff0c;Descriptions&#xff08;描述列表&#xff09;组件通常用于展示一系列的结构化信息。然而&#xff0c;需要明确的是&#xff0c;Element UI 官方库中并…

Hadoop升级失败,File system image contains an old layout version -64

原始版本 Hadoop 3.1.3 升级版本 Hadoop 3.3.3 报错内容如下 datasophon 部署Hadoop版本 查看Hadoop格式化版本 which hadoop-daemon.sh/bigdata/app/hadoop-3.1.3/sbin/hadoop-daemon.sh删除原来的旧版本 rm -rf /bigdata/app/hadoop-3.1.3查看环境变量 env|grep HADOOPHAD…

Java宝藏实验资源库(8)多态、抽象类和接口

一、实验目的 理解面向对象程序的基本概念。掌握类的继承和多态的实现机制。熟悉抽象类和接口的用法。 二、实验内容、过程及结果 **1.Using the classes defined in Listing 13.1, 13.2, 13.3, write a test program that creates an array of some Circle and Rectangle in…

高通安卓12-Input子系统

1.Input输入子系统架构 Input Driver(Input设备驱动层)->Input core(输入子系统核心层)->Event handler(事件处理层)->User space(用户空间) 2.getevent获取Input事件的用法 getevent 指令用于获取android系统中 input 输入事件&#xff0c;比如获取按键上报信息、获…

前端 CSS 经典:backface-visibility 属性

前言&#xff1a;backface-visibility 属性可以使反转 180deg 的元素隐藏&#xff0c;使用这个属性实现卡片翻转效果 效果 代码实现 <!DOCTYPE html> <html lang"en"><head><meta charset"utf-8" /><meta http-equiv"X-…