21、面向流水线的指令设计(下):奔腾4是怎么失败的?上一讲,我给你初步介绍了CPU的流水线技术。乍看起来,流水线技术是一个提升性能的灵丹妙药。它通过把一条指令的操作切分成更细的多个步骤,可以避免CPU“浪费”。每一个细分的流水线步骤都很简单,所以我们的单个时钟周期的时间就可以设得更短。这也变相地让CP...2025-11-01深入浅出计算机组成原理
20、面向流水线的指令设计(上):一心多用的现代CPU前面我们用了三讲,用一个个的电路组合,制作出了一个完整功能的CPU。这里面一下子给你引入了三个“周期”的概念,分别是指令周期、机器周期(或者CPU周期)以及时钟周期。 你可能会有点摸不着头脑了,为什么小小一个CPU,有那么多的周期(Cycle)呢?我...2025-11-01深入浅出计算机组成原理
19、建立数据通路(下):指令+运算=CPU上一讲,我们讲解了时钟信号是怎么实现的,以及怎么利用这个时钟信号,来控制数据的读写,可以使得我们能把需要的数据“存储”下来。那么,这一讲,我们要让计算机“自动”跑起来。 通过一个时钟信号,我们可以实现计数器,这个会成为我们的PC寄存器。然后,我们还需...2025-11-01深入浅出计算机组成原理
18、建立数据通路(中):指令+运算=CPU上一讲,我们看到,要能够实现一个完整的CPU功能,除了加法器这样的电路之外,我们还需要实现其他功能的电路。其中有一些电路,和我们实现过的加法器一样,只需要给定输入,就能得到固定的输出。这样的电路,我们称之为组合逻辑电路(Combinational L...2025-11-01深入浅出计算机组成原理
17、建立数据通路(上):指令+运算=CPU前面几讲里,我从两个不同的部分为你讲解了CPU的功能。 在“指令”部分,我为你讲解了计算机的“指令”是怎么运行的,也就是我们撰写的代码,是怎么变成一条条的机器能够理解的指令的,以及是按照什么样的顺序运行的。 在“计算”部分,我为你讲解了计算机的“计算...2025-11-01深入浅出计算机组成原理
16、浮点数和定点数(下):深入理解浮点数到底有什么用?上一讲,我们讲了用“浮点数”这样的数据形式,来表示一个不能确定大小的数据范围。浮点数可以大到$3.40×10^{38}$,也可以小到$1.17×10^{-38}$这样的数值。同时,我们也发现,其实我们平时写的0.1、0.2并不是精确的数值,只是一个近...2025-11-01深入浅出计算机组成原理