以 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)

相关推荐
Jay_Franklin2 分钟前
Quarto与Python集成使用
开发语言·python·markdown
Oueii36 分钟前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
2401_831824961 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
njidf2 小时前
Python日志记录(Logging)最佳实践
jvm·数据库·python
@我漫长的孤独流浪2 小时前
Python编程核心知识点速览
开发语言·数据库·python
宇擎智脑科技2 小时前
A2A Python SDK 源码架构解读:一个请求是如何被处理的
人工智能·python·架构·a2a
2401_851272992 小时前
实战:用Python分析某电商销售数据
jvm·数据库·python
vx_biyesheji00012 小时前
Python 全国城市租房洞察系统 Django框架 Requests爬虫 可视化 房子 房源 大数据 大模型 计算机毕业设计源码(建议收藏)✅
爬虫·python·机器学习·django·flask·课程设计·旅游
code 小楊2 小时前
yrb 1.5.0 正式发布:Python 极简国内下载加速与全景可视化终端体验!
开发语言·python
2401_857918292 小时前
用Python和Twilio构建短信通知系统
jvm·数据库·python