0

0

Python GIL 的存在原因与影响

舞夢輝影

舞夢輝影

发布时间:2026-01-29 18:24:39

|

322人浏览过

|

来源于php中文网

原创

GIL是CPython为简化引用计数内存管理而设的全局互斥锁,牺牲多线程CPU并行性以保障C扩展兼容与实现简单;Python 3.12仅优化为细粒度锁,未移除GIL。

python gil 的存在原因与影响

为什么 CPython 要加 GIL

GIL(Global Interpreter Lock)不是 Python 语言规范的一部分,而是 CPython 解释器实现层面的互斥锁。它的存在主要为了简化内存管理——CPython 的垃圾回收基于引用计数,而引用计数的增减操作必须是原子的。如果没有 GIL,多线程并发修改同一对象的 ob_refcnt 字段会导致计数错误、内存泄漏甚至崩溃。

换句话说,GIL 是用「牺牲并发性」换来了「实现简单性」和「C 扩展兼容性」。它让大量依赖 C API 的第三方库(如 numpycv2)无需额外加锁就能安全运行。

GIL 对多线程 CPU 密集型任务的实际影响

在纯计算场景下,GIL 会让多线程几乎无法并行利用多核:

  • threading.Thread 启动 4 个计算函数,实际仍是轮转执行,总耗时接近单线程 × 4
  • time.sleep() 或文件 I/O 等阻塞操作会主动释放 GIL,此时其他线程可抢占,所以多线程对 I/O 密集型任务仍有意义
  • numpyscipy 等底层用 C 实现的运算,通常会在执行前释放 GIL,因此多线程调用它们能真正并行

验证方式很简单:写一个死循环累加的函数,用 threadingmultiprocessing 分别跑 4 次,对比 time.time() 差值——前者基本不提速,后者接近 4 倍加速。

立即学习Python免费学习笔记(深入)”;

绕过 GIL 的常见路径与代价

真要并行 CPU 密集任务,主流做法只有三个,各自有明确取舍:

Magician
Magician

Figma插件,AI生成图标、图片和UX文案

下载
  • multiprocessing:每个进程有独立解释器和内存空间,天然绕过 GIL;但进程启动开销大、进程间通信(QueuePipe)比线程共享变量慢得多,且无法直接传 lambda 或闭包
  • asyncio + 协程:只适用于 I/O 密集场景,对 CPU 密集无效,因为协程仍运行在单线程中,不释放 GIL
  • 换解释器:比如 PyPy(部分场景无 GIL,但不保证)、Jython(JVM 上无 GIL)、Cython 编译关键函数为 C 扩展并在内部释放 GIL——但开发成本陡增,调试难度上升

注意:concurrent.futures.ThreadPoolExecutorProcessPoolExecutor区别,本质上就是上面两条路的封装,选错池子等于白忙活。

GIL 在 Python 3.12 中的改进与局限

Python 3.12 引入了「细粒度锁」机制,把原先一把大锁拆成多个更小的锁(如针对对象分配、GC、字节码执行等),理论上提升了多线程协作效率。但官方明确说明:这不等于移除 GIL,CPU 密集型纯 Python 代码依然无法并行。

实际效果取决于 workload 类型:如果线程频繁切换、做大量小对象创建/销毁,3.12 可能比 3.11 快 10% 左右;但如果主线程一直在跑 for i in range(10**8): x += i,其他线程依然拿不到 GIL。

真正想靠语言升级解决 GIL 问题,得等到「免 GIL 构建选项」稳定落地——目前还只是实验性编译开关(--without-pygil),连 alpha 都不算。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

207

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

191

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

55

2026.01.05

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

503

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

166

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

14

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

15

2026.01.21

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

166

2025.12.24

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

19

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号