问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

多核CPU调度是咋搞的?

创作时间:
作者:
@小白创作中心

多核CPU调度是咋搞的?

引用
CSDN
1.
https://blog.csdn.net/qq_63315166/article/details/144621658

为什么多核CPU用着用着会“躺平”?为什么手机有 8 核,跑分时性能却不是核心数的翻倍?答案的钥匙,就藏在多核CPU的调度机制里。

为了更直观地理解,以一个《王者荣耀》游戏服务器为例:

  • 每个战局就是一个进程(分配独立的内存空间)。
  • 战局里的每个英雄就是一个线程(共享战局内的资源)。

进程调度:擂台系统

单核CPU

  • 像打擂台,一个时间片内只能跑一个战局,其他战局只能在旁边“候场”。
  • 时间片轮转,每个进程轮流占用 CPU 执行。

多核CPU

  • 就像增加了多个擂台,不同的战局可以同时开打。
  • 但注意:某一时刻,一个核心只能运行一个进程
  • 32核的机器看似资源丰富,但如果战局安排不好(比如线程争抢资源),性能可能会被白白浪费。

线程调度:英雄的分工

线程是更细粒度的调度单位,一个进程中的线程可以分配到多个核心并行运行。

伪代码演示:

Process game_match {
    Thread hero1; // 可能在 CPU 核心1 运行
    Thread hero2; // 可能在 CPU 核心2 运行
    Thread hero3; // 可能在 CPU 核心3 运行
}

这意味着同一个战局里的英雄可以在不同核心同时开打。但调度不当时,可能会导致英雄之间“抢蓝buff”或者“技能冷却冲突”。

现实中效率低下的原因:8核不如4核?

为什么多核CPU用起来,效率反而降低了?有几个典型场景:

  • 线程同步开销(英雄CD等待):多个线程需要同步共享资源,比如锁、全局变量,这些操作可能导致线程“堵塞”,无法发挥多核并行的效果。
  • 资源竞争(抢蓝buff):如果多个线程争抢同一个资源(比如I/O设备、内存缓存),会引发资源争用,导致性能下降。
  • 缓存失效(切换英雄路线):如果线程频繁迁移核心,会导致 CPU 缓存(L1/L2/L3)失效,需要重新加载数据到缓存,性能反而会大幅下降。

调度的未来

很多现在的调度系统也正试图解决上面提到的问题:

  • Windows 的 Thread Director 技术:在混合架构(如 Intel 的 E 核+P 核)上,动态分配线程到高性能核心或高能效核心,实现性能与功耗的平衡。

  • Android 的 Energy Aware Scheduling(EAS):根据任务的重要性、功耗需求,智能分配线程到合适的核心上,提高电池续航。

  • 苹果 M 芯片的异构调度:将轻量任务分配到能效核心,重任务分配到性能核心,同时通过硬件加速器减轻CPU负担。

这些技术正在让多核系统的调度更高效、更智能,最大化性能的同时,降低功耗。

调度之道,如同太极

“看似繁杂的切换,暗含天地至理;貌似混乱的调度,实则蕴藏大智。”

多核调度并不是一场“蛮力竞赛”,它的艺术在于找到性能、功耗、复杂性之间的最佳平衡点。

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号