news 2026/4/18 12:24:02

python 全局解释器锁(GIL)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
python 全局解释器锁(GIL)

1、GIL(全局解释器锁)

python的GIL(Global Interpreter Lock,全局解释器锁)是CPython解释器(最主流的Python实现)中的一个核心机制,用于保证同一时刻只有一个线程执行Python字节码。它的存在深刻影响了Python的多线程性能,但也简化了CPython的内存管理和线程安全问题。

1.1、GIL的背景与目的

CPython是用C语言实现的Python解释器,其内存管理(如引用计数)并非线程安全,如果多个线程同时修改对象的引用计数,可能导致数据竞争或内存泄漏。为了简化设计,CPython引入了GIL:一个互斥锁,确保同一时间只有一个线程能执行Python代码(即持有GIL)。GIL的核心目的是保护CPython内部的数据结构(如对象、内存管理)免受多线程并发访问的破坏。

1.2、GIL 的工作原理

在CPython中,线程的执行流程如下:

  • 获取GIL:当一个线程开始执行Python代码时,必须先获取GIL。如果GIL已被其他线程占用,当前线程会被阻塞,直到GIL被释放。
  • 执行字节码:持有GIL的线程可以执行Python字节码(通常最多执行约100条指令,或通过sys.setcheckinterval调整)。
  • 释放GIL:当线程执行完一定数量的字节码、遇到I/O操作(如读写文件、网络请求),或主动调用time.sleep()时,会释放GIL,允许其他线程竞争。
  • 重新竞争GIL:释放GIL后,所有等待的线程会通过竞争(或操作系统调度)重新获取GIL,继续执行。

1.3、GIL对多线程的影响

GIL的存在导致Python多线程在CPU密集型任务​中无法充分利用多核CPU,但在I/O密集型任务​中仍能发挥作用。

CPU密集型任务(计算为主)

由于同一时间只有一个线程能执行Python代码,多线程无法并行利用多核。即使启动多个线程,它们也会轮流获取GIL,实际是串行执行。此时多线程的性能甚至可能不如单线程(因线程切换的开销)。

示例代码如下: #!/usr/bin/python3 import threading import time def count(n): sum = 0 for i in range(n): sum += i return sum # 单线程 start = time.time() count(10**8) print(f"单线程计算耗时:{time.time()-start:.2f}s") # 单线程计算耗时:3.61s # 多线程 start = time.time() t1 = threading.Thread(target=count,args=(5*10**7,)) t2 = threading.Thread(target=count,args=(5*10**7,)) t1.start() t2.start() t1.join() t1.join() print(f"双线程计算耗时:{time.time()-start:.2f}s") # 双线程计算耗时:3.68s,甚至更慢(线程切换开销)

I/O密集型任务(等待为主)

当线程遇到I/O操作(如网络请求、文件读写)时,会主动释放GIL,允许其他线程执行。此时多线程可以重叠等待时间,提升效率。

代码示例如下: #!/usr/bin/python3 import threading import time # 文件boot.img大小为17.2MB paths = ["boot.img"]*10 def readFile(path): file = open(path,"rb") while True: data = file.read() if not data: break file.close() start = time.time() for path in paths: readFile(path) print(f"单线程计算耗时:{time.time()-start:.8f}s") # 单线程计算耗时:0.04533887s start = time.time() threads = [] for path in paths: t = threading.Thread(target=readFile,args=(path,)) t.start() threads.append(t) for t in threads: t.join() print(f"多线程计算耗时:{time.time()-start:.8f}s") # 多线程计算耗时:0.02776027s(多线程显著更快,I/O等待时释放GIL)

GIL的争议与局限性

GIL是CPython 的一个经典设计权衡,但也备受争议:

  • 优点:简化了CPython的实现(无需复杂的线程安全设计),降低了开发者处理多线程的门槛。
  • 缺点:限制了CPU密集型任务的并行能力,不符合现代多核 CPU 的需求。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 2:13:51

基于STM32设计的智能防盗单车锁_349

文章目录 一、前言 1.1 项目介绍 【1】项目开发背景 【2】设计实现的功能 【3】项目硬件模块组成 【4】设计意义 【5】国内外研究现状 【6】摘要 1.2 设计思路 1.3 系统功能总结 1.4 开发工具的选择 【1】设备端开发 【2】上位机开发 1.5 框架图 1.6 原理图 二、硬件选型 2.1 S…

作者头像 李华
网站建设 2026/4/18 7:02:03

Wan2.2-T2V-A14B适用于直播内容生成吗?可行性分析

Wan2.2-T2V-A14B适用于直播内容生成吗?可行性分析 在今天的直播战场上,拼的早已不只是“谁嗓门大”或“谁话术溜”。观众要的是沉浸感、新鲜感和即时共鸣——你前脚刚说“这游戏超刺激”,后脚就得有爆炸特效炸出来;用户弹幕问“这…

作者头像 李华
网站建设 2026/4/18 3:00:02

挑战珠江极致光影,这部纪录片如何靠国产摄像机完成?

一条珠江,流淌着千年商贸往事与人文记忆。拍摄它的纪录片,却是一场对光影的终极挑战——变幻的天色、氤氲的水汽、宏大的江景与细腻的岸边细节,都在考验着每一台摄像机的极限。当《珠江》纪录片团队决定采用博冠B1 8K摄像机完成全片拍摄时&am…

作者头像 李华
网站建设 2026/4/18 5:39:17

thinkphp8下carbon的使用示例

composer require nesbot/carbonuse Carbon\Carbon; use think\response\Json;class Demo {public function index(): string{// 全局设定(一次即可)date_default_timezone_set(Asia/Shanghai);Carbon::setLocale(zh_CN);// 当前时间对象$now Carbon::n…

作者头像 李华
网站建设 2026/4/17 22:00:56

每日Java面试场景题知识点之-工厂方法模式

每日Java面试场景题知识点之-工厂方法模式 场景问题描述 在开发一个电商平台支付系统时,技术团队面临以下挑战: 系统需要集成多种支付渠道,包括支付宝、微信支付、银联支付等。最初采用硬编码方式实现支付逻辑,每次新增支付渠道都…

作者头像 李华