以 Core i9-13900HX 实例讲解CPU概念:物理CPU,内核,逻辑CPU

缘起

复制代码
# 完整代码见:https://github.com/luminousmen/grokking_concurrency/blob/master/Chapter%205/password_cracking_parallel.py

def crack_password_parallel(crypto_hash: str, length: int) -> None:
    """Orchestrate cracking the password between different processes"""
    # getting number of available processors
    num_cores = os.cpu_count()
   。。。

看书的时候看到一行代码加一句注释包含了三个概念:processorcpucore。因为之前没用过 os.cpu_count(),所以一下子有点懵,这个函数到底返回什么,为什么用了三个概念?

在梳理概念的过程中发现很多文章缺乏图,单纯的文字不大好理解。于是以自己电脑的 Core i9-13900HX 处理器为例,进行实例讲解,希望对那些对此也有困惑的人员有所帮助。

物理 CPU/处理器(processor)

定义

安装在主板插槽(socket)上的一个物理元件(物理的意思:看得见,摸得着)。称为:物理 CPU,处理器(processor)。我们平时去买电脑时会问"这台电脑是什么处理器?",其实就是问这台电脑的物理 CPU 是什么?老板可能会回答"这台联想拯救者(Y9000P)电脑的处理器是 Core i9-13900HX "。

实物图

Core i9-13900HX

如上图所示:我的联想拯救者(Y9000P)电脑有 1 个物理 CPU(处理器),型号是 Core i9-13900HX。

物理内核(Physical core)/内核(Cores)

定义

位于 CPU 内部的一个物理元件。称为:物理内核(physical core),内核(core)

实物图

sorry~ 因为核是封装在物理 CPU 内部的,具体长什么样我也不确定,待确定后再补充。

Core i9-13900HX


如上图所示:Core i9-13900HX 是大小核架构:性能核(Performance-core) + 能效核(Efficient-core)。性能核有 8 个,能效核有 16 个,总计:8 + 16 = 24。即一个物理 CPU Core i9-13900HX 有 24 个内核,或者说有"一个物理 CPU Core i9-13900HX 有 24 个物理内核"

逻辑CPU(logical CPUs)/线程(Threads)

定义

一个虚拟元件(虚拟的意思:逻辑上的,看不见,摸不着)。称为:逻辑 CPU(logical CPU),逻辑处理器(processor),逻辑内核(logical core),线程(thread)

Core i9-13900HX

如上图所示:每个性能核(Performance-core)有 2 个线程,能效核(Efficient-core)有 1 个线程,总计:8 x 2 + 16 x 1 = 32 。即 "一个物理 CPU Core i9-13900HX 有 24 个内核,32 个线程",或者说 "一个物理 CPU Core i9-13900HX 有 24 个内核,32 个逻辑 CPU"。

注:

1.这里的"线程"和"编程中多线程的线程"不是同一个概念。

2.编程中有些描述会直接用 CPU 表示 logical CPU,如:

复制代码
# 得到的也是 logial CPUs
multiprocessing.cpu_count()
    Return the number of CPUs in the system.

3.有些文章用 logical cores 表示 logical CPUs,个人觉得这样容易和 physical core 混淆,应该少用 logical cores , 多用 logical CPUs。

编程实战

psutil.cpu_count(logical=True)

复制代码
# 参考资料:https://psutil.readthedocs.io/en/latest/#psutil.cpu_count
psutil.cpu_count(logical=True)
    Return the number of logical CPUs in the system (same as os.cpu_count) or None if undetermined. "logical CPUs" means the number of physical cores multiplied by the number of threads that can run on each core (this is known as Hyper Threading). If logical is False return the number of physical cores only, or None if undetermined. On OpenBSD and NetBSD psutil.cpu_count(logical=False) always return None. 

如上所述:psutil.cpu_count(logical=True ) 获取的"逻辑CPU(logical CPUs) "的数量,psutil.cpu_count(logical=False ) 获取的"物理内核(Physical core)/内核(Cores)"的数量。

os.cpu_count()

复制代码
# 参考资料: https://docs.python.org/3/library/os.html
os.cpu_count()
    Return the number of logical CPUs in the system. Returns None if undetermined.

如上所述: os.cpu_count() 获取的是"逻辑CPU数(logical CPUs)"。

复制代码
import os

import psutil

num_cores = psutil.cpu_count(logical=False)
# Core i9-13900HX 电脑上输出为 24
print(f'CPU cores: {num_cores}')

# 也可以用 psutil.cpu_count(logical=True)
num_logical_cpus = os.cpu_count()
# Core i9-13900HX 电脑上输出为 32
print(f'logical CPUs: {num_logical_cpus}')

欢迎搜索及关注:编程人(a_codists)

相关推荐
大、男人17 分钟前
python之Starlette
python·uvicorn
小智RE0-走在路上2 小时前
Python学习笔记(11) --数据可视化
笔记·python·学习
历程里程碑2 小时前
hot 206
java·开发语言·数据结构·c++·python·算法·排序算法
Coder_Boy_2 小时前
Java+Proteus仿真Arduino控制LED问题排查全记录(含交互过程)
java·人工智能·python
qq_356196952 小时前
day47_预训练模型与迁移学习@浙大疏锦行
python
Tipriest_3 小时前
C++ 的 ranges 和 Python 的 bisect 在二分查找中的应用与实现
c++·python·算法·二分法
老歌老听老掉牙3 小时前
符号计算中的表达式等价性验证:数学等价性与计算简化策略分析
python·数学建模·sympy
scan7243 小时前
向量数据库检索
python
摸鱼仙人~3 小时前
一文详解PyTorch DDP
人工智能·pytorch·python
超级种码3 小时前
Java:JavaAgent技术(java.instrument和java.attach)
java·开发语言·python