1 计算机体系结构

计算机革命发展得非常快速,以至于使用老式计算机的很多电影现在看起来十分有年代感,有的电影甚至无法预料后来的计算机是什么样的。

计算机各个组成部分的技术发展非常不均衡,各部分性能差异非常大。在计算机的发展前期,几乎没有人敢想以后居然能用上便捷式计算机。对于计算机来说,老式计算机一般都要接上电源,而现在的笔记本电脑、ipad,基本上都可以利用外部电源来解决电源问题。

除了电源问题外,功耗问题也存在。一个狭小的计算机空间如何解决处理器产生的热量,是非常重要的课题,尽管后来出现了多核处理器,但是计算机的性能依旧上不去,绝大部分原因来源于散热。

1.1 计算机系统体系结构

1.1.1 简单的计算机结构

媒体一直把一个微处理器(microprocessor)或者一块芯片(chip)叫做计算机系统。这实际上是不对的,计算机系统应该包括中央处理单元(cemtral processing unit,CPU),保存程序和数据的存储器,以及将芯片转换为实用系统的其他子系统。这些子系统会使得CPU和其他外部设备的通信变得更加容易。

计算机执行程序的部分叫做CPU,也叫处理器微处理器则是在单个硅片上实现的CPU。围绕着微处理器构建的计算机被称作微机

CPU尽管是核心,但是计算机性能可不仅仅取决于此,如果处理的数据来源慢,处理再快又有什么用,还不是等人送数据进来才能处理。在过去的几十年,处理器性能持续高速增长,而硬盘的性能几乎不变,等到固态硬盘诞生后,这种矛盾才趋于缓和。

下图描述了一个简单的计算机系统的结构:

其中信息保存在存储器,而存储器一般分为多种,如主存、缓存、辅存、寄存器等等。这里图中出现了Cache。Cache一般指的是高速缓存,在以前Cache一般位于CPU之外,而在现在大多数Cache都在CPU内部。

Cache存储器,电脑中为高速缓冲存储器),是位于CPU和主存储器DRAM(Dynamic Random Access Memory)之间,规模较小,但速度很高的存储器,通常由SRAM(Static Random Access Memory 静态存储器组成。它是位于CPU与内存间的一种容量较小但速度很高的存储器。CPU的速度远高于内存,当CPU直接从内存中存取数据时要等待一定时间周期,而Cache则可以保存CPU刚用过或循环使用的一部分数据,如果CPU需要再次使用该部分数据时可从Cache中直接调用,这样就避免了重复存取数据,减少了CPU的等待时间,因而提高了系统的效率。Cache又分为L1Cache(一级缓存)和L2Cache(二级缓存),L1Cache主要是集成在CPU内部,而L2Cache集成在主板上或是CPU上。

需要注意的是,对应的信息在适当的时刻存放在适当的存储器,这点十分重要,如果存放不当,即使CPU再快也只能干等。

图中主存一般指的是内存、寄存器,而辅存一般指外存(如磁盘、CD-ROM等)。而总线一般是用来传输各个子系统之间的通信,确保数据能够从计算机的一个位置传输到另外一个位置。

寄存器一般处于CPU内部,用来存放数据。对于常用的数据,一般先放在存储器,放不下了就放到高速缓冲去,再放不下就转移到磁盘。

1.1.2 计算机

定义计算机时必须指明计算机的类型。冯诺依曼是最早界定计算机结构的人之一。计算机有很多种,常见的有个人计算机、手机、模拟计算机、神经计算机、量子计算机等。

通用的数字计算机一般分为两部分:CPU存储器系统。CPU读程序来完成程序指定的操作。存储器系统保存两类信息:程序程序产生的数据

程序和程序产生的数据不一定要放在同一个存储器系统内,但是现在大多数计算机系统都是放在同一个存储器系统。这种计算机叫做存储程序计算机

计算机可以看做是一个黑盒子,它将信息从一个位置转移到另外一个位置并且处理,这个转移的过程通常是由总线来完成,CPU通过总线传来的信息读取出其中的指令,然后进行处理。需要注意的是,处理数据完成后,可能要把数据传回存储器。

一个简单的处理数据的过程如下所示:

对两个数X和Y做加法。最开始CPU会从存储器读取一条指令,这条指令通过CPU的分析和解码后,就获得了这条指令所需的数据。此时X和Y会从存储器中取出,然后分别放于不同寄存器中,当读取相加指令的时候,就把两个寄存器内部的内容相加,并把结果保存在第三个寄存器中,最后再根据指令把数据写回存储单元。

一般来说,传数据和传指令的总线只有一条,数据和指令轮流使用;当然也有个例,比如哈佛体系结构计算机。

1.2 体系结构的构成

1.2.1 概述

在上面我们曾经提到寄存器。一般来说寄存器用来存放一个单位的数据或字数据。由于其处于CPU内部,在计算机内,它的访问速度远远快于CPU外的存储器。

对于体系结构的构成来说,有时候体系结构组成两个术语会交差使用,但是实际上体系结构构成是有区别的,举个例子,时钟的体系结构是定义在有刻度的表盘上转动指针,而它的组成可以是机械钟,石英钟,电子钟。

上述的例子说明了组成是体系结构的子集,给定的体系结构可以有不同的组成方式。

对于程序员来说,计算机底层原理实际上都被屏蔽掉了,我们并不关心X+Y是什么底层逻辑在相加,而在意其结果。计算机体系结构的这个抽象视图现在通常被叫做指令集体系结构

计算机是由二进制的0和1组成的串,这串也被叫做机器码。人类可读的机器码叫做汇编语言。而能够在类型完全不同的计算机上运行,和底层计算机体系结构没有关系的代码叫做高级语言。任何代码写完之后,运行前都需要先通过编译器的编译,转换为本地机器码之后才能运行。

指令集体系结构包括了数据类型、保存临时结果的寄存器、指令的类型和格式以及寻址方式。术语微代码是定义在芯片上的一组执行基本操作(微指令)的代码,执行这些操作可以解释机器码。

在这门知识结构体系中,我们用体系结构来代表计算机的抽象指令集体系结构,而用组成来代表计算机的硬件实现。而后会用术语微体系结构来描述CPU的实现。

1.2.2 计算机系统和技术

下图的分类表明了设计计算机所要考虑的要素。

1.2.2.1 技术

20世纪70年代以来,半导体技术一直遵循着摩尔定律的预测而发展。摩尔定律表明了芯片的集成度每18个月翻一番。有时候意味着处理器的性能每18月翻一番。

1.2.2.2 应用

有些计算机用于嵌入式、有些计算机用于个人工作、有些计算机用于电视、游戏机,对于不同的应用场景计算机的设计也会有所不同。

1.2.2.3 工具

计算机硬件的设计软件也会影响计算机的设计,你要用什么样的软件去设计硬件,这取决于软件产品做的好不好,精度高不高。

1.2.3 计算机体系结构在计算机科学的地位

工欲善其事必先利其器,对于想要学习计算机的人,不知道计算机组成原理怎么行;对于想优化代码的,在了解了计算机体系结构后就会思考到对应的优化方案,进而付出实践。

时钟

也许你听到这个术语,你第一个想到的是我们现实的时钟;实际上在计算机操作系统、计算机组成原理、数字电路设计都会涉及到这个术语。在绝大多数数字电路中都带有一个时钟,用来生成连续的间隔固定的电脉冲流。之所以叫做时钟,无非是因为可以利用它来确定计算机的一些事件的顺序。

事件由时钟信号触发的数字电路被称作同步。有些事件则是异步的,比如移动鼠标,移动了他才会向计算机发送信号,这是个先动后发的过程,属于异步事件。然而,计算机在每个时钟脉冲都会去检查一下鼠标在干嘛,这是一个同步事件

例如我们说的时钟中断,在所有外部中断中,时钟中断起着特殊的作用。因为计算机是以精确的时间进行数值运算的数据处理的,最基本的时间单元是时钟周期。例如取指令,执行指令,存取内存等都依靠时钟进行时间的确定。

计算机组成原理随笔(一)相关推荐

  1. 计算机组成原理-第二章 数据表示与运算

    计算机组成原理-第二章 数据表示与运算 一.数据的表示 1.数值型数据的表示(重点难点) 1.1数值型数据的表示--进位制 1.2数值型数据表示-码制 1.3数值型数据的表示--定点数 1.4数值型数 ...

  2. 计算机组成原理-第一章

    计算机组成原理第一章概述 一.计算机系统概述 1. 定义 2.分类 3.计算机系统的抽象层次 二.计算机系统的组成 1.计算机系统的硬件组成 1.1冯.诺依曼计算机(重点) 1.2现代计算机结构 1. ...

  3. 计算机组成原理读写周期波形图,第3章存储器层次结构-1讲述.ppt

    第3章存储器层次结构-1讲述 计算机组成原理 * 计算机组成原理 --存储器层次结构(1) 2016-3-18 几个基本概念 1.存储器:计算机系统中的记忆设备,用来存放程序和数据. 2.存储元:存储 ...

  4. 计算机原理说课教案,《 计算机组成原理 》 说课

    < 计算机组成原理 > 说课 View 114 Download 5 Embed Size (px) 344 x 292429 x 357514 x 422599 x 487 DESCRI ...

  5. 计算机组成原理2套题,计算机组成原理试卷及答案2套.doc

    计算机组成原理试卷A 选择题(每小题2分,共30分) 下列数中最小的数是______. A.(100100)2 B.(43)8 C.(110010)BCD D.(25)16 计算机经历了从器件角度划分 ...

  6. 计算机组成原理实验pc,计算机组成原理实验报告5- PC实验

    计算机组成原理实验报告5- PC实验 2.5 PC实验 姓名:孙坚 学号:134173733 班级:13计算机 日期:2015.5.15 一.实验要求:利用CPTH 实验仪上的K16..K23 开关做 ...

  7. 《计算机组成原理》----2.6 浮点数

    本节书摘来自华章出版社<计算机组成原理>一书中的第2章,第2.6节, 作 者 Computer Organization and Architecture: Themes and Vari ...

  8. 计算机组成原理文华学院,华中科技大学文华学院计算机组成原理课设.doc

    <华中科技大学文华学院计算机组成原理课设.doc>由会员分享,提供在线免费全文阅读可下载,此文档格式为doc,更多相关<华中科技大学文华学院计算机组成原理课设.doc>文档请在 ...

  9. 微型计算机组成原理考试,全国高等教育自学考试计算机组成原理模拟试题

    第一部分 选择题(共15分) 一.单项选择题(本大题共15小题,每小题1分,共15分.在每小题列出的四个备选项中只有一个是符合题目要求的,请将其代码填写在题后的括号内.错选.多选或未选均无分.) 1. ...

最新文章

  1. 《Linux实践及应用》
  2. tar:file-changed-as-we-read-it报错处理
  3. Java实现ANN神经网络之BP代码参考
  4. [Spark]Could not locate executable null\bin\winutils.exe in the Hadoop binaries
  5. java search 不能使用方法_ElasticSearch实战系列三: ElasticSearch的JAVA API使用教程
  6. android 分享qq微信朋友圈,H5微信JS-SDK实现分享朋友 朋友圈以及QQ自定义分享
  7. Centos安装Clion
  8. logistic回归__基于Python和Numpy函数库
  9. win7录屏_win7/win10电脑屏幕录像工具哪款比较好?--QVE屏幕录制
  10. 卡西欧计算机能开根号吗,考研计算器怎么开根号
  11. 怎么把python压缩_python中如何实现图片压缩
  12. lisp 获取横断面数据_基于Visual LISP全路线横断面数据自动提取
  13. APP日志的抓取方法——转载
  14. 4.VEH(向量化异常处理)
  15. 虚拟机未正常关闭,结果再次启动的时候打不开了?
  16. windows搜索文件内容的软件推荐
  17. 用python计算复利和年化收益率
  18. Vue复习笔记 (二)SPA单页面应用(优化首屏加载)
  19. 亚马逊AWS Kinesis Video Streams with KVS demo示例
  20. AssertionError: Some objects had attributes which were not restored:

热门文章

  1. 2015 CALLED THE INTERFACE OF 2014
  2. CAS去掉HTTPS认证
  3. 项目实践中Linux集群的总结和思考
  4. java处理高并发高负载类网站问题
  5. 一起来看流星雨剧情简介/剧情介绍/剧情分集介绍第六集
  6. 在应用程序级别以外使用注册为 allowDefinition='MachineToApplication' 的节是错误
  7. 深入理解InnoDB(4)—索引使用
  8. p2020开发_2020年最佳开发者社区
  9. 如果您是JavaScript开发人员,为什么要进行增强现实-以及如何开始
  10. 协作机器人 ai算法_如果我们希望人工智能为我们服务而不是不利于我们,我们需要协作设计...