Python 多线程(threading)和 多进程(multiprocessing)核心区别

文章目录

一、一句话总结区别

多线程:轻量、共享内存、受 GIL 限制,适合 IO 密集型任务(爬虫、文件、网络请求)

多进程:重量、独立内存、绕过 GIL,适合 CPU 密集型任务(计算、压缩、加密)


二、详细对比表(最清晰)

对比项 多线程(threading) 多进程(multiprocessing)
资源占用 极轻量,创建快、开销小 重量,创建慢、开销大
内存共享 共享同一块内存 完全独立内存空间
GIL 限制 受 GIL 限制,无法多核并行 绕过 GIL,真正多核并行
数据安全 不安全,必须加锁 天然安全,互不干扰
切换速度 极快 较慢
适用场景 IO 密集型 CPU 密集型
稳定性 一个线程崩溃可能拖垮整个进程 一个进程崩溃不影响其他

三、3 个最关键的核心区别

1. GIL 全局解释器锁(Python 独有!最重要)

  • 多线程 :同一时刻,只有 1 个线程在执行 Python 代码 ,没法利用多核 CPU。
    但遇到 IO 等待(爬虫、读文件)时会自动释放 GIL,所以IO 任务能提速
  • 多进程 :每个进程有独立的 GIL,多核 CPU 可以同时跑,纯计算速度成倍提升。

2. 内存是否共享

  • 多线程 :所有线程共用一份数据,修改变量容易错乱,必须加锁
  • 多进程 :每个进程有自己独立的数据副本,互不影响,天然安全

3. 开销大小

  • 多线程:像打开多个标签页,几乎不占额外资源。
  • 多进程:像打开多个浏览器窗口,系统资源占用大很多。

四、最实用:你的任务该选哪个?

✅ 选 多线程(threading)

  • 网络爬虫、API 接口请求
  • 文件批量读写、日志处理
  • 数据库查询、socket 通信
  • 所有等待时间 > 计算时间的任务

✅ 选 多进程(multiprocessing)

  • 大量数值计算、数据分析
  • 视频/图片压缩、加密解密
  • 机器学习模型推理
  • 所有纯 CPU 运算的任务

五、最简单的选择口诀(背会就行)

IO 密集用多线程,轻量高效不占资源;

CPU 密集用多进程,多核加速计算飞快;

共享数据用线程(加锁),独立安全用进程。


六、简单代码对比(一眼看懂)

多线程:共享变量、轻量

python 复制代码
import threading
# 多线程共享全局变量
num = 0

多进程:独立空间、真正并行

python 复制代码
import multiprocessing
# 多进程互不共享,必须用队列/管道通信

相关推荐
MageGojo1 小时前
基于 API Zero 平台集成 TTS 语音合成服务的技术实践
python·语音合成·tts·restful api·api集成
YsyaaabB1 小时前
LangChain作业二---多语言翻译Prompt
开发语言·python·langchain
HappyAcmen1 小时前
2.PDF长文档完整读取
python·pdf·rag
装不满的克莱因瓶1 小时前
掌握感知器的学习原理
人工智能·python·神经网络·算法·ai·卷积神经网络
py小王子2 小时前
Nature 期刊图复现|Python 实现双轴高维直方图与重叠分布图
python·nature·期刊图复现
小熊Coding2 小时前
从零打造一款回合制 RPG 游戏:基于 Pygame 的《塔影守卫》全解析
python·游戏·计算机专业·pygame·rpg·2d游戏
myenjoy_12 小时前
串口采集与 Modbus RTU——字节流里的时间敏感博弈
网络·python·网络协议·tcp/ip
易舟云财务软件2 小时前
财务 AI Python 实战:从自动化报表到智能风控的应用场景
人工智能·python·自动化
武雄(小星Ai)2 小时前
一个模型干五件事:拆解 NVIDIA Cosmos 3 的物理 AI 全模态架构
人工智能·python·agent