美文网首页就该这么学并发
08. 今天, 小姐姐突然问了我一个问题……

08. 今天, 小姐姐突然问了我一个问题……

作者: 码哥说 | 来源:发表于2020-08-06 10:01 被阅读0次

前言

今天,

妹子突然找我,

问了我一个问题……

糟了是心动的感觉.gif_的表情包

她要买笔记本电脑 (突然的失望……)

她不是小白, 知道电脑要看内存, CPU,显卡以及固态硬盘等等

甚至知道 N卡A卡的区别

image

但是依旧被CPU的

“i5处理器 双核四线程”

“i5处理器 双核双线程”

……

这些描述给整懵了...

妹子知道我是“码农”,

所以直接问我了

“ CPU的双核双线程和双核4线程有啥什么区别? ”

虽然我不明白“码农”为什么要知道这些……

一脸懵逼 - 一脸懵逼 彩虹懵逼_的表情包

**

不过, 巧了, 咸鱼君刚好知道!(差点不知道, 多影响形象!)
那么, 在CPU中,所谓的核心数,所谓的线程数究竟代表着什么?

CPU

  • CUP核数

CUP核数即一个CPU由多少个核心组成,核心数越多, 代表这个CPU的运转速度越快, 性能越好.
工地搬砖头 (处理一堆数据),
单核CPU相当于1个人搬砖头,
双核CPU相当于2个人搬砖头,
4核CPU相当于4个人搬砖头,
………………
通常 人越多, 搬砖头效率越高!(处理核心数越多, CPU的工作效率也就越高)

  • CUP线程数

CPU的线程数是指逻辑上处理单元,
它是Intel提出的逻辑概念, 只有Intel的CPU才有核心线程数;
依托于Intel的超线程技术,它让操作系统识别到有多个处理单元.
你可以简单的认为,
线程数就是核心数, 只不过它是模拟的, 并不是和核心数一样, 是物理上真实存在的.

我们以拥有单个的CPU的系统举例

  • 单核单线程

CPU上只有一个核心, 所以只能串行处理任务, 效率极其低下, 早期的计算机就是这样

  • 单核多线程

通过Intel超线程技术来让单核CPU模拟出多核的CPU的效果.
如果没有超线程技术, 一个CPU核心只能对应一个线程;
而使用了超线程技术, 一个CPU核可以模拟出多线程CPU(可以理解为多核CPU);
对于一个CPU, 线程数总是大于或等于核心数.
这里有一点强调下,
模拟这个词说明不是真正的多核心, 区别可以看下面“超线程技术”的实现原理

  • 超线程技术

超线程这个概念是Intel提出的,
简单来说是在单核的CPU上并发多个线程;
听起来似乎不太可能, 因为单核CPU都是分时的;
其实这里也是分时的, 一个CPU除了处理器核心还有其他设备(寄存器、L1L2缓存等等),
一段代码执行过程中也不光是只有处理器核心工作,
如果两个线程A和B,
A正在使用处理器核心, B正在使用缓存或者其他设备, 那AB两个线程就可以并行;
但是如果AB都在访问同一个设备, 那就只能等前一个线程执行完后一个线程才能执行(此时是并发);

实现这种并发的原理是在CPU里加了一个协调辅助核心,
根据Intel提供的数据,这样一个设备会使得设备面积增大5%,但是性能提高15%~30%.

咸鱼君和妹子 balabala 说了一通, 大致意思就是

CPU的核数就是真正的计算核心, 线程数是英特尔处理器特有的来模拟核心的东东, 并不是物理上真实存在的

妹子回了句“哦”

…………

我曾经失落失望失掉所有方向.jpg_的表情包

好吧, 既然都谈到这个了, 接下来再聊几个问题~

CPU为什么要多核?
一个多核的CPU也就是一个CPU上有多个处理器核心,这样有什么好处呢?

假设现在我们要在一台计算机上跑一个多线程的程序,
因为是一个进程里的线程,所以需要一些共享一些存储变量;
如果这台计算机都是单核单线程CPU,
就意味着这个程序的不同线程需要经常在CPU之间的外部总线上通信,
同时还要处理不同CPU之间不同缓存导致数据不一致的问题,
所以在这种场景下多核单CPU的架构就能发挥很大的优势,通信都在内部总线,共用同一个缓存.

为什么要多CPU?
前面提了多核的好处,那为什么要多CPU呢?

这个其实很容易想到,
如果要运行多个程序(进程)的话,
假如只有一个CPU的话, 就意味着要经常进行进程的上下文切换,
因为单CPU即便是多核的,也只是多个处理器核心,其他设备都是共用的,
所以 多个进程就必然要经常进行进程上下文切换,这个代价是很高的.

另外就是一个制造成本的问题,
单个CPU我们不可能无限制叠加核心,
就算可以, 那成本也是随着核心数呈几何级增加的,
所以不如多用几个核心少点的CPU,
毕竟, “三个臭皮匠, 顶个诸葛亮”

为什么要多线程?

一个进程里多线程之间可以共享变量, 线程间通信开销也较小, 可以更好的利用多核CPU的性能;
多核CPU上跑多线程程序往往会比单线程更快,
有的时候甚至在单核CPU上多线程程序也会有更好的性能,
因为虽然多线程会有上下文切换和线程创建销毁开销,
但是单线程程序会被IO阻塞无法充分利用CPU资源,
加上线程的上下文开销较低以及线程池的大量应用,
多线程在很多场景下都会有更高的效率.

欢迎关注我

技术公众号 “CTO技术”

相关文章

  • 08. 今天, 小姐姐突然问了我一个问题……

    前言 今天, 妹子突然找我, 问了我一个问题…… 她要买笔记本电脑 (突然的失望……)​ 她不是小白, 知道电脑要...

  • 他突然问了我一个问题

    老公开车时突然向后座的我提问: “认识快四年了,我在你心目中是个什么样的人呢?” 我沉默了蛮久,然后连续几天都在思...

  • 这个世界上谁的兄弟姐妹最多?说出来你可能不信哦

    今天宝宝问我,很多小朋友都有哥哥姐姐,弟弟妹妹,为什么我没有? 我只好开始向他普及常识,突然宝宝问了一个有趣的问题...

  • 04夜空中闪耀的星——铍元素

    “老师,我有个问题。”在我上课的课堂上,我惊讶地看着提问的同学,小雯在班上很少发言,今天突然问了我一个问题,还真的...

  • 没脸皮和二皮脸

    女儿刚上小学的时候,有一天突然对我我说:“妈妈,姐姐(她姑姑的女儿)问了我一个问题。” 我知道,女儿这...

  • 有趣地游戏

    今天,下午我姐姐在脑筋急转弯地游戏。我问了姐姐一个问题,问题是,怎样才能最快地把一页练字本写完?姐姐绞尽脑汁地想了...

  • 表扬的力量

    今天晚上跟儿子聊天。儿子:“今天我同桌问了我一个问题,我突然不知道怎么回答啦?” 我好奇地问:“啥问题啊?” 儿子...

  • «洛克菲勒写给儿子的38封信»读后感(七)

    今天下午在小馆认识了一个姐姐,姑且叫姐姐吧,看上去大概40多岁了,一张嘴问了一个很尴尬的问题,问人家小孩多大了,回...

  • 你最想得到的是什么?

    昨晚和姐姐读书的时候,有一个问题是“你最想得到的是什么?”我就着这个问题问了小姐姐。 我:姐姐,你觉得你最想得到的...

  • 小答应问了一个好问题

    前两天发了一个说说,内容是想表达,标点符号对文章和读者的影响,没想到小答应今天来问了一个问题。 看到他狡诈的笑容,...

网友评论

    本文标题:08. 今天, 小姐姐突然问了我一个问题……

    本文链接:https://www.haomeiwen.com/subject/quwdhktx.html