

新闻资讯
技术教程GIL是CPython为简化引用计数内存管理而设的解释器级互斥锁,使CPU密集型多线程无法并行,但I/O密集型仍可并发;可通过multiprocessing、支持GIL释放的库或换用无GIL解释器来绕过。
Python 的 GIL(Global Interpreter Lock,全局解释器锁)不是 Python 语言本身的限制,而是 CPython 解释器实现层面的设计选择。它导致同一时刻只有一个线程在执行 Python 字节码,因此 CPU 密集型多线程程序无法真正并行,但 I/O 密集型任务仍能受益于多线程带来的并发性。
GIL 的核心目的是简化内存管理——CPython 使用引用计数作为主要垃圾回收机制,而引用计数的增减操作必须是原子的。若允许多线程同时修改对象引用计数,就需要对每个对象加锁,开销极大。GIL 是一个解释器级的互斥锁,保证任意时刻仅一个线程执行字节码,从而避免了细粒度锁的复杂性和性能损耗。
对于 I/O 密集型任务,GIL 的影响很小。因为线程大部分时间在等待系统调用返回,期间 GIL 已被释放,其他线程可继续执行。
此时多线程能提升整体吞吐量,虽非“并行”,但实现了高效的“并发”。
如果任务主要消耗 CPU(如数值计算、图像处理、加密解密),多线程几乎不提速。正确做法是绕过 GIL:
可以写两个对比实验:一个纯 CPU 计算用 threading,另一个用 multiprocessing,观察耗时差异。
例如计算斐波那契第 35 项 10 次:
U 核心数(接近线性加速)注意:进程启动和数据序列化有额外开销,小任务反而更慢——合理选择并发模型比盲目上多线程更重要。