GIL是CPython中限制同一时刻仅一个线程执行字节码的互斥锁,导致CPU密集型任务无法多核并行;I/O操作会自动释放GIL,使线程在I/O密集场景下呈现并发效果。
Python 的线程在 CPython 解释器下不是真正的并发执行,而是协作式地轮流获得 GIL(全局解释器锁)的执行窗口——这决定了它无法利用多核 CPU 并行执行 CPU 密集型任务。
GIL 是 CPython 解释器内部的一把互斥锁,同一时刻只允许一个线程执行 Python 字节码。即使你启用了 10 个线程,它们也必须排队等待获取 GIL 才能运行。
time.sleep())会触发线程自动释放 GIL,此时其他线程可抢占执行因为 GIL 的切换足够快,加上 I/O 等待期间的让出,使得多个线程在宏观上呈现“同时进行”的效果,尤其在 I/O 密集型场景中体验良好。
对 CPU 密集型任务,需用不依赖 CPython GIL 的方案:
multiprocessing):每个进程有独立解释器和 GIL,天然并行,适合数据独立、可序列化的任务asyncio):单线
numba/cython:在 C 层释放 GIL 后做计算,再安全回调 Python运行以下代码,观察 CPU 使用率和耗时:
(注:实际运行时请取消注释并替换为你的测试函数)import threading import timedef cpu_bound_task():
模拟纯计算:不触发 I/O,GIL 不易释放
s = 0 for i in range(10**7): s += i * i return s单线程
start = time.time() cpu_bound_task() print("单线程耗时:", time.time() - start)
4 线程(实际仍是串行)
threads = [threading.Thread(target=cpu_boundtask) for in range(4)] start = time.time() for t in threads: t.start() for t in threads: t.join() print("4 线程耗时:", time.time() - start)
你会发现:4 线程版本耗时接近单线程的 4 倍,且 CPU 占用基本不超 100%,这就是 GIL 在起作用。