https://gitee.com/fakerlove/computer-organization

文章目录

  • 1. 概述
    • 1.1 发展历程
    • 1.2 计算机系统层次结构
      • 1.2.1 五大部件
        • 1) 存储器
        • 2) 运算器
        • 3) 控制器
        • 4) 输入设备
        • 5) 输出设备
      • 1.2.2 指令完成
    • 1.3 计算机硬件指标
      • 1.3.1 字长
        • 机器字长
        • 存储字长
        • 指令字长
        • 编址
      • 1.3.2 运算速度
        • 1) 各种周期比较
        • 2) CPI
        • 3) 主要的计算
      • 1.3.3 存储容量
      • 1.3.4 专业术语
        • 兼容

1. 概述

1.1 发展历程

1.2 计算机系统层次结构

1.2.1 五大部件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IldidAp3-1609145991290)(picture/3007300-9560bf42265d71eb.png)]

1) 存储器

类比:

  • 存储体 — 存储单元 — 存储原件(0/1)
  • 大楼 — 房间 — 床位 (有人/没人)

重要概念:

  • 存储单元 :存放一串二进制代码(可能是指令,也可能是数据)
  • 存储字 : 存储单元中二进制代码的组合
  • 存储字长:存储单元中二进制代码的位数(32位/64位)

每个存储单元赋予一个地址号,每个存储单元中存放一个存储字;存储单元按地址寻访

  • MAR(Memory Address Register)存储器地址寄存器:存地址的,反映存储单元的个数

  • MDR(Memory Data Regester)存储器数据寄存器:存数据的,反映存储字长

    设MAR=4位 说明存储单元个数是2的4次方=16个(反映存储单元的个数);

    MDR=8位,说明存储字长8位

解释:计算机中的主存数据寄存器(MDR),与主存地址寄存器(MAR)帮助完成CPU和主存储器之间的通信:

  • MAR用来保存数据被传输到的位置的地址或者数据来源位置的地址;
  • MDR保存要被写入地址单元或者从地址单元读出的数据。

2) 运算器

运算器的功能是什么,如何工作?

  • 加法运算
  • 乘法运算
  • 或与非

运算器结构:

  • ALUArithmetic Logic Unit):算数逻辑单元,核心运算单元;通常是个组合电路,其特点是如果输入撤销,那么输出结果也会撤销,所以如果要保存结果需要在输入输出端加上相应的寄存器(ACC,X);
  • ACC(Accumulator):累加器;
  • X: 数据寄存器;
  • MQ:乘商寄存器(在乘法过程中,产生的结果是操作数的两倍)为了把乘法结果都保存下来,需要此寄存乘法增加的部分;
ACC MQ X
加法 被加数、和 加数
减法 被减数、差 减数
乘法 乘法结果的高位 乘数、乘法结果的低位 被乘数
除法 被除数、余数 除数

乘法:加法+移位操作 (这里有点不太清楚)

除法:减法+移位操作 (这里有点不太清楚)

(回去看看《编码》、《CSAPP》第二章理解理解,再回过来看看)

3) 控制器

功能:

  • 解释指令
  • 保证指令按顺序执行

基本结构:

完成一条指令:

  • 取指令(PC)
  • 分析指令(IR)
  • 执行指令(CU)

结构:

  • CU:核心控制单元,执行指令
  • PC:程序计数器,用来存放当前要执行指令的地址,具有计数功能(PC) + 1 —> PC(不同的机型,这里不一定+1,即相邻两个指令的物理地址不一定相邻)
  • IR:指令寄存器,存放当前欲执行的指令

4) 输入设备

5) 输出设备

1.2.2 指令完成

这里要好好理解每一个指令步骤,理解了每一个步骤就相当于理解了这一章。

(1)主机完成一条取数指令的步骤

取数指令的功能:把存储体(主存/内存)中的数存到ACC中

完成一条指令的三个阶段:

  1. 取指令
  2. 分析指令
  3. 执行指令

(注:指令:操作码+地址码)

取数操作步骤分析(如图):

  1. 要执行的指令的地址保存在PC中,指令保存在存储体中;第一步将PC中要执行的指令的地址放入MAR;
  2. MAR将指令地址送给存储体M;
  3. 在控制器的控制下,存储体M将指令地址中的指令送给MDR;
  4. 在控制器的控制下,将MDR中的指令存到IR中;(到此,取指令的操作完成;PC—>MAR—>M—>MDR—>IR)
  5. 分析指令:将IR中指令的操作码部分给CU,由CU去分析控制执行;
  6. 把IR中指令中待取的数的地址部分送到MAR;
  7. MAR将数的地址送给存储体M;
  8. 在控制器的控制下,存储体M将数的地址中的数送给MDR;
  9. 在控制器的控制下,MDR中的数交给ACC保存。

(2)主机完成一条存数操作步骤

存数指令的功能:把存放在ACC中的计算结果存到内存单元M中

存数操作步骤分析(如图):

  1. 要执行的指令的地址保存在PC中,指令保存在存储体中;第一步将PC中要执行的指令的地址放入MAR;
  2. MAR将指令地址送给存储体M;
  3. 在控制器的控制下,存储体M将指令地址中的指令送给MDR;
  4. 在控制器的控制下,将MDR中的指令存到IR中;(到此,取指令的操作完成;PC—>MAR—>M—>MDR—>IR)
  5. 分析指令:将IR中指令的操作码部分给CU,由CU去分析控制执行;
  6. 把IR中指令中待存的数的地址送到MAR;(从这一步开始不同)
  7. MAR将数的地址送给存储体M,告诉存储体要存进来一个数,其地址是多少;
  8. 在控制器的控制下,将ACC中要存的数交给MDR;
  9. 在控制器的控制下,将MDR中的数交给存储体。

1.3 计算机硬件指标

1.3.1 字长

机器字长

CPU一次能处理数据的位数(如可以对两个8位二进制数进行加法,就是8位),与CPU中的寄存器(ACC,X,MQ)的位数有关。

  • 一般来说,机器字长越长性能越好。
  • 机器字长反映了计算机的运算精度,即字长越长,数的表示范围也越大,精度也越高。

存储字长

一个存储单元存储一串二进制代码(存储字专),这属串二进制代码的位数称为存储字长,存储字长可以是8位、16位、32位等。

指令字长

一个指令字中包含二进制代码的位数。

编址

  • 按字编址,就是机器字长编址,机器为32 位,4B就是一个单位,机器字长为64 位,8B就是一个单位
  • 按字节编址,1B就是 一个单位

1.3.2 运算速度

前两个是硬件指标;后四个是从指令执行的角度来衡量的。

1) 各种周期比较

时钟周期 时钟周期是计算机中最基本的、最小的时间单位 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-39NdjQE4-1609145991302)(picture/37d3d539b6003af3e3559f24382ac65c1138b683)]
机器周期(cpu周期) 机器周期也称为CPU周期。在计算机中,为了便于管理,常把一条指令的执行过程划分为若干个阶段(如取指、译码、执行等),每一阶段完成一个基本操作。完成一个基本操作所需要的时间称为机器周期。一般情况下,一个机器周期由若干个时钟周期组成
指令周期 一般由若干个机器周期组成,是从取指令,分析指令到执行完所需的全部时间。
取指周期 间址周期 执行周期 中断周期
存储周期 存储器进行一次“读”或“写”操作所需的时间称为存储器的访问时间(或读写时间),而连续启动两次独立的“读”或“写”操作(如连续的两次“读”操作)所需的最短时间,称为存取周期(或存储周期)。
存取时间 存储访问时间,也可以称之为存取时间,是指从启动一次存储器操作到完成该操作所经历的时间
总线周期 总线周期通常指的是CPU完成一次访问MEM或I/O端口操作所需要的时间。一个总线周期由几个时钟周期组成。

将机器周期定为单位1ns,则指令周期为1~4ns,时钟周期为1/6s,总线周期为2/3ns(一个总线周期一般包含bai4个时钟周期)。

存取时间<存储周期

时钟周期<机器周期<指令周期

2) CPI

CPU 执行一条指令所需的时钟周期数

系统结构,指令集,计算机组织都会影响CPI,而时钟频率不会

3) 主要的计算

MIPS=主频CPI,如果主频是GHz的话,需要乘以1000,因为GHz=109Hz,而MIPS的单位是106MIPS=\frac{主频}{CPI},如果主频是GHz的话,需要乘以1000,因为GHz=10^9Hz,而MIPS的单位是10^6MIPS=CPI主频​,如果主频是GHz的话,需要乘以1000,因为GHz=109Hz,而MIPS的单位是106
时钟周期=1主频,时间单位换算为GHz=ns(纳秒),MHz=μs(微秒),KHz=ms(毫秒)时钟周期=\frac{1}{主频},时间单位换算为 GHz=ns(纳秒) ,MHz=\mu s(微秒),KHz= ms(毫秒)时钟周期=主频1​,时间单位换算为GHz=ns(纳秒),MHz=μs(微秒),KHz=ms(毫秒)

1.3.3 存储容量

存放二进制信息的总位数

1.3.4 专业术语

兼容

软件或者硬件上的通用
通常在同一系列不同型号的计算机间通用

2022年考研计算机组成原理_1 概述相关推荐

  1. 2022年考研计算机组成原理_6 总线

    https://gitee.com/fakerlove/computer-organization 文章目录 6. 总线 6.1 概述 6.1.1 概念 6.1.2 分类 按功能层次分类 按数据线的多 ...

  2. 2022年考研计算机组成原理_7 输入输出系统

    https://gitee.com/fakerlove/computer-organization 文章目录 7. 输入输出系统 7.1 基本概念 7.1.1 I/O系统演变过程 7.1.2 I/O系 ...

  3. 2022年考研计算机组成原理_5 中央处理器

    https://gitee.com/fakerlove/computer-organization 文章目录 5. 中央处理器 5.1 CPU 的结构 5.1.1 CPU 功能 5.1.2 CPU的结 ...

  4. 2022年考研计算机组成原理_2 数据表示和运算

    https://gitee.com/fakerlove/computer-organization 文章目录 2. 数据表示和运算 2.1 数据与编码 2.1.1 进制转换 2.1.2 校验码 2.2 ...

  5. 2022年考研计算机组成原理_4 指令系统

    https://gitee.com/fakerlove/computer-organization 文章目录 4. 指令系统 4.1 指令系统的基本概念 4.1.1 指令的基本格式 1) 四地址指令 ...

  6. 计算机组成原理 外部设备分为,2017考研计算机组成原理第七章考点:外部设备...

    2017考研计算机组成原理第七章考点:外部设备 2016-03-15 13:33 | 考研集训营 对于参加计算机统考的学生来说,2017考研的准备工作需要提前进行,因为计算机考研专业课涵盖了四门科目, ...

  7. 计算机组成原理浮点数左移规则,2020考研计算机组成原理知识点:浮点数的表示和运算...

    2020年计算机考研复习已经开始,新东方在线在此整理了2020考研计算机组成原理知识点:浮点数的表示和运算,希望能帮助大家! 浮点数的表示和运算 1. 浮点数的表示 1)浮点数的表示范围; 浮点数是指 ...

  8. 【考研计算机组成原理】课堂笔记目录汇总——知识点清晰

    文章目录: 一:基础笔记 二:强化笔记 三:冲刺笔记 一:基础笔记 [考研计算机组成原理]课堂笔记1 第一章 计算机系统概论Introduction to computer systems [考研计算 ...

  9. 2018考研计算机原理,2018考研计算机组成原理名词释义(8)

    2018考研计算机组成原理名词释义(8) 2017-08-10 13:57 | 考研集训营 对于参加计算机统考的学生来说,2018考研的准备工作需要提前进行,因为计算机考研专业课涵盖了四门科目,考察范 ...

最新文章

  1. minor gc和Major GC,Full GC的触发条件
  2. 实探全球第九大超算中心:温水冷却节能30% 正寻求新突破
  3. 用Fiddler对Android应用进行抓包
  4. 从零开始用TensorFlow搭建卷积神经网络
  5. SpringBoot - 统一格式封装及高阶全局异常处理
  6. 标准CC++获取当前时间(毫秒级)
  7. 论文笔记 《Selective Search for Object Recognition》
  8. 【听哥一句劝,C++水很深,你把握不住啊!】C++提高班之 符与*符
  9. 【视频】vue指令之v-if、v-bind
  10. JavaScript中map函数和filter的简单举例
  11. 两个水平排列的div顶部对齐~详细
  12. test软件工程第三次作业
  13. mongo 3.0 备份和还原数据库 ,及too many positional arguments错误
  14. vb.net的socket编程
  15. 计算机怎么取消账户密码怎么设置,电脑开机密码怎么设置以及取消
  16. 程序员发布:一张图读懂支撑阿里双十一1682亿的技术架构体系
  17. 听风的插件-正在战斗中
  18. 微信Markdown-here的CSS样式——不断调整
  19. 哈里斯鹰优化(HHO)算法(含MATLAB代码)
  20. 大学生活质量指北,高考毕业生填报志愿参考必备

热门文章

  1. currenthashmap线程安全的原因
  2. matlab 可能未使用callback,MATLAB 的 CALLBACK函数.
  3. 支付宝生活号获取uid踩坑实践
  4. FSMC驱动TFTLCD原理详解
  5. Oracle TRUNC 函数详解
  6. 实体类用int还是Integer
  7. Git学习笔记【尚硅谷】
  8. CreateProcess 输出重定向
  9. 淘淘商城第91讲——SSO系统分析
  10. 网络编程实践陈硕笔记零