计算机系统概论要点记录--2个重要理念及7层转换

原创 2016年08月30日 10:57:36

两个反复出现的重要理念

1. 抽象

2. 脑子里不要对软件和硬件做任何区分

 

学会“抽象”是个重要的进步,它让我们站在更高的层次看问题,从而将事物的本质表现出来,而将其细节隐藏;它让我们更有效的使用大脑,提升工作效率。

但是如果事物出现问题,要想发现问题所在,就必须深入到每个组成的实现细节里去——分解抽象。

如果我们不需要将一个组件和其他的东西相结合,以构建更大的系统,那么将认识停留在抽象层面就万事大吉了。但事实上,我们肯定需要将这些组件拼装成更大的系统,而这些组件在一起工作的时候,也难免会出错误。

因此实际工作中,抽象与分解抽象,总是伴随存在。

抽象


脑子里不要对软件和硬件做任何区分,它们只是计算机系统中两个组成部分的名称而已;对设计者来说,将计算机的某个功能划分给哪部分实现,以及它们之间如何协同工作,原则只有一个:让计算机工作得最棒!

比如历史上,intel处理器的设计者就意识到,未来的程序将包含大量的视频信息,所以在他们设计的处理器中,内嵌了专用视频处理硬件,为此intel提出了MMX指令集及MMX专用执行硬件。

个人感想:“软件最后总要转换成cpu可执行的指令,而指令就对应着硬件,要么有专用的执行硬件,要么是间接的执行硬件,比如历史上早期是没有乘法器的,所有的乘法工作都转换成加法(间接执行硬件),后来为了提高效率,研究出了专用的乘法器(专用执行硬件)。自己以前想既然mmx,sse那么厉害,增加几十条指令就提高效率,为什么不增加个几百条呢?太蠢了”


两个重要的思想

1. 所有的计算机,不管是大的还是小的,快的还是慢的,贵的还是廉价的,只要给予足够的时间和内存,它们所能完成的计算任务是相同的。这就是阿兰图灵的思想——通用计算。

2. 我们用英语或者其他语言给出一个问题,然而计算机却能通过电子运转来解决这个问题。看起来不可思议,但却被成功解决了。

 

                         问题
                         算法
                         语言
                        指令集
                        微结构
                         电路
                         器件

从用自然语言对问题进行描述开始,直到电子的实际运转,之间要经历多个层次的转换。在转换过程中,每一层的实现又都存在很多选择方案。

算法:确定性、可计算性、有限性。不同的算法可以描述同一个问题。

语言:高级语言与汇编语言相比,也不能向底层表述更多的计算方式,它们都被转换为特定机器的指令集。

指令集:不同的ISA定义的操作类型、数据类型和寻址模式的数目都是不同的。有的ISA只有几个操作类型,有的ISA有上百个;有的ISA只有一种数据类型,有的则有几十种;有的ISA只有一两种寻址模式,有的则有20多种。

微结构: 实现指令集的具体组织被称为微结构,同一个ISA,具体实现的微结构方案不同。

逻辑电路:微结构最终是由一组简单的逻辑电路实现,同一个微结构,具体实现的电路方案不同。

器件:每个逻辑电路,都是按照特定的器件技术来实现的。

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

计算机组成原理----第一章计算机系统概论---错题集第一部分

1.以加法指令ADD M(M为主存储地址)为例,写出完成该指令的信息流程(从取指令开始)。...

读书笔记:《计算机系统概论》——第七章:汇编语言

汇编语言 从本章开始,编程语言从机器语言上升到了汇编语言。汇编语言属于低级语言,一般低级语言是“ISA相关的”,而高级语言是“ISA无关的”。 汇编语言相对于机器语言的进步是:由助记符来表...

读书笔记:《计算机系统概论》——第五章:LC-3结构

指令集架构(Instruction Set Architecture,ISA) ISA定义了软件编程所需要的必要而完整的描述,具体来说,ISA定义了3个东西:操作码的集合、数据类型和寻址模式 指令...

计算机系统概论

Introduction to Computer System:From Bits and Gates to C and Beyond 很可惜很悲哀的是,我现在还停留在摘抄的阶段!! 【Yale N....
  • ZCedar
  • ZCedar
  • 2013年03月20日 12:40
  • 673

读书笔记:《计算机系统概论》——第三章:数字逻辑

本章节从MOS晶体管这个逻辑单元的最基本的要素开始说起,基于MOS晶体管来实现逻辑门(Logic Gate),然后通过逻辑门互连构成计算机的各种电路,这些电路可以分为两大类:组合逻辑电路和存储逻辑电路...

读书笔记:《计算机系统概论》——第四章:冯·诺依曼模型

当今社会中我们所用的个人计算机,基本上都是基于冯·诺依曼模型设计的。冯·诺依曼模型包括5个部分: 内存(memory)、处理单元(processing unit)、输入(input)、输出(outpu...

第1章 计算机系统概论--笔记

本系列博文的主要目的是为了本人保研/考研作笔记所用。参考自《计算机组成原理》(第2版)唐朔飞 如有侵权,请联系本人撤下 计算机组成和计算机体系结构的区别: 计算机体系结构指的是能被我们看...
  • Ace_Yom
  • Ace_Yom
  • 2015年08月14日 17:18
  • 608

Linux设备驱动程序(第三版)/深入理解计算机系统(原书第2版)/[Android系统原理及开发要点详解].(韩超,梁泉)百度云盘下载

文档下载云盘连接:http://pan.baidu.com/s/1dDD2sgT 更多其他资料,请关注淘宝:http://shop115376623.taobao.com/ http://...

深入理解计算机系统(2.6)---二进制整数的乘、除法运算(重要)【困难度高】

2.5我们着重介绍了二进制整数的加、减运算,本次我们继续介绍乘、除运算。本章是迄今为止最难的一章,希望各位猿友有所收获,也别忘了“点个推荐哦”。   引言     运算一直是程序运行当中一个重...

深入理解计算机系统(2.3)---整数的表示方式精解》无符号与补码编码(重要)

上一章我们简单的介绍了布尔代数以及C语言的位运算,本次我们主要来看,二进制如何表示整数,这是很重要的一章,希望各位猿友莫要错过。   C语言中的整数类型及范围              我们依...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:计算机系统概论要点记录--2个重要理念及7层转换
举报原因:
原因补充:

(最多只允许输入30个字)