CPU的工做原理

CPU的原始工做模式

  在了解CPU工做原理以前,咱们先简单谈谈CPU是如何生产出来的。CPU是在特别纯净的硅材料上制造的。一个CPU芯片包含上百万个精巧的晶体管。人们在一块指甲盖大小的硅片上,用化学的方法蚀刻光刻出晶体管。所以,从这个意义上说,CPU正是由晶体管组合而成的。简单而言,晶体管就是微型电子开关,它们是构建CPU的基石,你能够把一个晶体管看成一个电灯开关,它们有个操做位,分别表明两种状态:ON(开)和OFF(关)。这一开一关就至关于晶体管的连通与断开,而这两种状态正好与二进制中的基础状态“0”和“1”对应!这样,计算机就具有了处理信息的能力。

  但你不要觉得,只有简单的“0”和“1”两种状态的晶体管的原理很简单,其实它们的发展是通过科学家们多年的辛苦研究得来的。在晶体管以前,计算机依靠速度缓慢、低效率的真空电子管和机械开关来处理信息。后来,科研人员把两个晶体管放置到一个硅晶体中,这样便创做出第一个集成电路,再后来才有了微处理器

  看到这里,你必定想知道,晶体管是如何利用“0”和“1”这两种电子信号来执行指令和处理数据的呢?其实,全部电子设备都有本身的电路和开关,电子在电路中流动或断开,彻底由开关来控制,若是你将开关设置为OFF,电子将中止流动,若是你再将其设置为ON,电子又会继续流动。晶体管的这种ON与OFF的切换只由电子信号控制,咱们能够将晶体管称之为二进制设备。这样,晶体管的ON状态用“1”来表示,而OFF状态则用“0”来表示,就能够组成最简单的二进制数。众多晶体管产生的多个“1”与“0”的特殊次序和模式能表明不一样的状况,将其定义为字母、数字、颜色和图形。举个例子,十进位中的1在二进位模式时也是“1”,2在二进位模式时是“10”,3是“11”,4是“100”,5是“101”,6是“110”等等,依此类推,这就组成了计算机工做采用的二进制语言和数据。成组的晶体管联合起来能够存储数值,也能够进行逻辑运算和数字运算。加上石英时钟的控制,晶体管组就像一部复杂的机器那样同步地执行它们的功能。

  CPU的内部结构

  如今咱们已经大概知道CPU是负责些什么事情,可是具体由哪些部件负责处理数据和执行程序呢?

1.算术逻辑单元ALU(Arithmetic Logic Unit)
  ALU是运算器的核心。它是以全加器为基础,辅之以移位寄存器及相应控制逻辑组合而成的电路,在控制信号的做用下可完成加、减、乘、除四则运算和各类逻辑运算。就像刚才提到的,这里就至关于工厂中的生产线,负责运算数据。

2.寄存器组 RS(Register Set或Registers)
  RS实质上是CPU中暂时存放数据的地方,里面保存着那些等待处理的数据,或已经处理过的数据,CPU访问寄存器所用的时间要比访问内存的时间短。采用寄存器,能够减小CPU访问内存的次数,从而提升了CPU的工做速度。但由于受到芯片面积和集成度所限,寄存器组的容量不可能很大。寄存器组可分为专用寄存器和通用寄存器。专用寄存器的做用是固定的,分别寄存相应的数据。而通用寄存器用途普遍并可由程序员规定其用途。通用寄存器的数目因微处理器而异。

3.控制单元(Control Unit)
  正如工厂的物流分配部门,控制单元是整个CPU的指挥控制中心,由指令寄存器IR(Instruction Register)、指令译码器ID(Instruction Decoder)和操做控制器0C(Operation Controller)三个部件组成,对协调整个电脑有序工做极为重要。它根据用户预先编好的程序,依次从存储器中取出各条指令,放在指令寄存器IR中,经过指令译码(分析)肯定应该进行什么操做,而后经过操做控制器OC,按肯定的时序,向相应的部件发出微操做控制信号。操做控制器OC中主要包括节拍脉冲发生器、控制矩阵、时钟脉冲发生器复位电路和启停电路等控制逻辑。

4.总线(Bus)
  就像工厂中各部位之间的联系渠道,总线其实是一组导线,是各类公共信号线的集合,用于做为电脑中全部各组成部分传输信息共同使用的“公路”。直接和CPU相连的总线可称为局部总线。其中包括: 数据总线DB(Data Bus)、地址总线AB(Address Bus) 、控制总线CB(Control Bus)。其中,数据总线用来传输数据信息;地址总线用于传送CPU发出的地址信息;控制总线用来传送控制信号时序信号和状态信息等。

  CPU的工做流程

  由晶体管组成的CPU是做为处理数据和执行程序的核心,其英文全称是:Central Processing Unit,即中央处理器。首先,CPU的内部结构能够分为控制单元,逻辑运算单元和存储单元(包括内部总线缓冲器)三大部分。CPU的工做原理就像一个工厂对产品的加工过程:进入工厂的原料(程序指令),通过物资分配部门(控制单元)的调度分配,被送往生产线(逻辑运算单元),生产出成品(处理后的数据)后,再存储在仓库(存储单元)中,最后等着拿到市场上去卖(交由应用程序使用)。在这个过程当中,咱们注意到从控制单元开始,CPU就开始了正式的工做,中间的过程是经过逻辑运算单元来进行运算处理,交到存储单元表明工做的结束。

  数据与指令在CPU中的运行

  刚才已经为你们介绍了CPU的部件及基本原理状况,如今,咱们来看看数据是怎样在CPU中运行的。咱们知道,数据从输入设备流经内存,等待CPU的处理,这些将要处理的信息是按字节存储的,也就是以8位二进制数或8比特为1个单元存储,这些信息能够是数据或指令。数据能够是二进制表示的字符、数字或颜色等等。而指令告诉CPU对数据执行哪些操做,好比完成加法、减法或移位运算

  咱们假设在内存中的数据是最简单的原始数据。首先,指令指针(Instruction Pointer)会通知CPU,将要执行的指令放置在内存中的存储位置。由于内存中的每一个存储单元都有编号(称为地址),能够根据这些地址把数据取出,经过地址总线送到控制单元中,指令译码器指令寄存器IR中拿来指令,翻译成CPU能够执行的形式,而后决定完成该指令须要哪些必要的操做,它将告诉算术逻辑单元(ALU)何时计算,告诉指令读取器何时获取数值,告诉指令译码器何时翻译指令等等。

  假如数据被送往算术逻辑单元,数据将会执行指令中规定的算术运算和其余各类运算。当数据处理完毕后,将回到寄存器中,经过不一样的指令将数据继续运行或者经过DB总线送到数据缓存器中。

  基本上,CPU就是这样去执行读出数据、处理数据和往内存写数据3项基本工做。但在一般状况下,一条指令能够包含按明确顺序执行的许多操做,CPU的工做就是执行这些指令,完成一条指令后,CPU的控制单元又将告诉指令读取器从内存中读取下一条指令来执行。这个过程不断快速地重复,快速地执行一条又一条指令,产生你在显示器上所看到的结果。咱们很容易想到,在处理这么多指令和数据的同时,因为数据转移时差和CPU处理时差,确定会出现混乱处理的状况。为了保证每一个操做准时发生,CPU须要一个时钟,时钟控制着CPU所执行的每个动做。时钟就像一个节拍器,它不停地发出脉冲,决定CPU的步调和处理时间,这就是咱们所熟悉的CPU的标称速度,也称为主频。主频数值越高,代表CPU的工做速度越快。

  如何提升CPU工做效率

  既然CPU的主要工做是执行指令和处理数据,那么工做效率将成为CPU的最主要内容,所以,各CPU厂商也尽力使CPU处理数据的速度更快。

  根据CPU的内部运算结构,一些制造厂商在CPU内增长了另外一个算术逻辑单元(ALU),或者是另外再设置一个处理很是大和很是小的数据浮点运算单元(Floating Point Unit,FPU),这样就大大加快了数据运算的速度。

  而在执行效率方面,一些厂商经过流水线方式或以几乎并行工做的方式执行指令的方法来提升指令的执行速度。刚才咱们提到,指令的执行须要许多独立的操做,诸如取指令和译码等。最初CPU在执行下一条指令以前必须所有执行完上一条指令,而如今则由分布式的电路各自执行操做。也就是说,当这部分的电路完成了一件工做后,第二件工做当即占据了该电路,这样就大大增长了执行方面的效率。

  另外,为了让指令与指令之间的链接更加准确,如今的CPU一般会采用多种预测搜索方式来控制指令更高效率地执行。
程序员

相关文章
相关标签/搜索