大家好,今天小编关注到一个比较有意思的话题,就是关于单cpu多线程的问题,于是小编就整理了1个相关介绍单cpu多线程的解答,让我们一起看看吧。
多核的CPU可以运行一个进程下的多个线程吗?
如果想弄清楚多核CPU如何运行,以及线程与进程的概念,需要回顾一下计算机软硬件的知识。我们从早期单核CPU开始。
早期单核CPU架构
早期的电路设计能力不支持一个CPU有多核,比较经典的架构如上图所示。
一个单核CPU的架构包括:
我们以一个加法运算来解释上面这些概念。对于一个2 + 2的加法,人类可以直接说出答案,但是换成13234 + 87912,就不得不拿出纸和笔来算一下了。计算机对这两次计算速度没有差别,其本质为半导体电路对两个数字执行加法操作。但与人类不同的是,计算机需要知道两个问题:
因此,控制单元先取指令 Fetch,然后指令译码 Decode解析出要执行什么指令,并确认指令是对哪些数据(操作数 operand)进行操作,并将操作数从主存加载到寄存器中。ALU执行指令 Execute后结果写回 Store。
多核
当单个CPU主频超过一定范围后,CPU成本和散热成了很大的问题,主频很难突破10GHz。为了获得更快的计算速度和更好的性能,芯片设计者决定绕过主频,采用人海战术,在一块CPU中增加多个核心(Core)。
一个核心是一个可以运行指令的独立单元,它包含了前面所提到的ALU和寄存器,并配备L1和L2 Cache。多个核心共享L3 Cache。
上图中是一个多核处理器的电路图,每个Core旁边的黑色圆圈分别为L1和L2 Cache。可以看到CPU中,各类Cache占用了很大的空间。
个人电脑上的CPU一般是单个Processor,每个Processor有多个Core。服务器上的CPU是多个Processor,每个Processor有多个Core,提供更多计算核心。支持单个CPU的服务器被称为单路服务器,支持两个CPU的服务器被称为双路服务器,支持四个CPU的服务器被称为四路服务器。上图展示了Intel的四路架构,系统支持四个CPU,假如每块CPU内有8个核心,系统可对外提供32核计算能力。
存储金字塔
要了解计算机的运行原理,除了CPU,我们还要聊聊内存。随着技术的发展,计算机的速度瓶颈已经变成了超高速的CPU运算速度与落后的数据读取速度之间的矛盾。CPU计算速度在纳秒级别,但是CPU读取主存的速度竟有百纳秒,CPU进行完计算后,要闲置几十倍的时间,实在是巨大的浪费。从计算本身来说,某个程序一般不需要把硬盘或主存中的所有数据都拿来进行计算,绝大多数时间只需要处理部分热点数据,因此,把热点数据加载到缓存中能解决绝大多数问题。综合计算速度、技术水平、生产成本,设计人员给CPU增加了很多中间的缓存Cache。
到此,以上就是小编对于单cpu多线程的问题就介绍到这了,希望介绍关于单cpu多线程的1点解答对大家有用。