Cpython解释器中的GIL全局解释器锁


Posted in Python onNovember 09, 2020

1、什么是GIL全局解释器锁

GIL:Global Interpreter Lock,意思就是全局解释器锁,这个GIL并不是Python的特性,他是只在Cpython解释器里引入的一个概念,而在其他的语言编写的解释器里就没有GIL,例如:Jython,Pypy等

下面是官方给出的解释:

In CPython, the global interpreter lock, or GIL, is a mutex that prevents multiple native threads from executing Python bytecodes at once. This lock is necessary mainly because CPython's memory management is not thread-safe. (However, since the GIL exists, other features have grown to depend on the guarantees that it enforces.)

翻译过来的意思就是:在CPython中,全局解释器锁(GIL)是一个互斥锁,可以防止多个本地线程同时执行Python字节码。这个锁是必要的,主要是因为CPython的内存管理不是线程安全的。(但是,由于GIL存在,其他特性已经发展到依赖于它所执行的保证。)

所以:

GIL本质上就是一把互斥锁,用来保证数据的正确性,使数据可以正常同步。

GIL就像是BUG一般存在的全局互斥锁,目前无法通过代码去除GIL

结论:在CPython解释器中,在同一个进程下开启的多线程,同一时刻只能有一个线程执行,无法利用多核优势

PS:我们平常所使用的python是C语言编写的,所以大部分人所说的python也指CPython,CPython是python的官方版本,若是指其他语言写的python,一般情况下会指明,如Jypthon、Pypy等

2、为什么会出现GIL

随着电脑多核CPU的出现,python为了充分利用多核CPU,进行多线程的编程方式便普及了起来,但是随之而来的困难是线程之间数据的一致性和状态同步,python为了解决这个数据不能同步的问题,所以设计了GIL全局解释器锁,其实就是互斥锁

说到互斥锁,在多线程互斥锁中共享全局变量的时候会有线程对全局变量进行的资源竞争,会对全局变量的修改产生不是我们想要的结果,而那个时候用到的是python中线程模块里面的互斥锁。

如下例(未加线程互斥锁):

from threading import Threadimport time


n = 100
def task():
  global n
  m = n
  time.sleep(0.5)  # 模拟IO操作
  n = m - 1


if __name__ == '__main__':
  list1 = []
  for i in range(10):
    t = Thread(target=task)
    t.start()
    list1.append(t)

  for t in list1:
    t.join()

  print(n)

 执行结果:

99

在上面的例子里,我创建了10个线程来争夺对 n 进行 -1 操作,但是结果并非我想要的,所以我在这里加入了互斥锁

如下例(加线程互斥锁):

from threading import Thread
from threading import Lock
import time


n = 100
def task(lock):
  global n
  lock.acquire()  # 加锁
  m = n
  time.sleep(0.5)  # 模拟IO操作
  n = m - 1
  lock.release()  # 解锁


if __name__ == '__main__':
  list1 = []
  lock = Lock()
  for i in range(10):
    t = Thread(target=task, args=(lock, ))
    t.start()
    list1.append(t)

  for t in list1:
    t.join()

  print(n)

执行结果:

90

这次就可以得到我想要的结果

3、GIL的优缺点

优点:

保证数据的正确性

缺点:

单个进程下,开启多个线程,牺牲了执行效率,无法实现并行,只能实现并发

4、如何体现GIL全局解释器锁

在Cpython解释器中,当python代码有一个线程开始访问解释器的时候,GIL会把这个大锁给锁上,此时此刻其他的线程只能干等着,无法对解释器的资源进行访问,这一点就和互斥锁相似。而只是这个过程发生在我们的Cpython中,同时也需要等这个线程分配的时间到了,这个线程把GIL释放掉,类似互斥锁的lock.release()一样,另外其他的线程才开始跑起来。

Cpython解释器中的GIL全局解释器锁

以上就是Cpython解释器中的GIL全局解释器锁的详细内容,更多关于GIL全局解释器锁的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
详解Python中的join()函数的用法
Apr 07 Python
Python安装Numpy和matplotlib的方法(推荐)
Nov 02 Python
Python基于回溯法解决01背包问题实例
Dec 06 Python
Python 获得命令行参数的方法(推荐)
Jan 24 Python
numpy 计算两个数组重复程度的方法
Nov 07 Python
Python中变量的输入输出实例代码详解
Jul 28 Python
浅谈keras 模型用于预测时的注意事项
Jun 27 Python
Python自动巡检H3C交换机实现过程解析
Aug 14 Python
python实现视频压缩功能
Dec 18 Python
python实现双人五子棋(终端版)
Dec 30 Python
详解在OpenCV中如何使用图像像素
Mar 03 Python
python 闭包函数详细介绍
Apr 19 Python
OpenCV实现机器人对物体进行移动跟随的方法实例
Nov 09 #Python
基于python爬取梨视频实现过程解析
Nov 09 #Python
Python eval函数介绍及用法
Nov 09 #Python
python tkinter的消息框模块(messagebox,simpledialog)
Nov 07 #Python
python 用struct模块解决黏包问题
Nov 07 #Python
python hmac模块验证客户端的合法性
Nov 07 #Python
python如何利用paramiko执行服务器命令
Nov 07 #Python
You might like
PHP以及MYSQL日期比较方法
2012/11/29 PHP
php5.3提示Function ereg() is deprecated Error问题解决方法
2014/11/12 PHP
js查找父节点的简单方法
2008/06/28 Javascript
jquery tools之tabs 选项卡/页签
2009/07/25 Javascript
不使用中间变量,交换int型的 a, b两个变量的值。
2010/10/29 Javascript
js基于面向对象实现网页TAB选项卡菜单效果代码
2015/09/09 Javascript
AngularJS基础 ng-model 指令详解及示例代码
2016/08/02 Javascript
js防阻塞加载的实现方法
2016/09/09 Javascript
bootstrap快速制作后台界面
2016/12/05 Javascript
three.js实现炫酷的全景3D重力感应
2018/12/30 Javascript
详解Vue webapp项目通过HBulider打包原生APP(vue+webpack+HBulider)
2019/02/02 Javascript
Elasticsearch实现复合查询高亮结果功能
2019/09/10 Javascript
JavaScript实现抖音罗盘时钟
2019/10/11 Javascript
微信小程序激励式视频广告组件使用详解
2019/12/06 Javascript
vue 使用rules对表单字段进行校验的步骤
2020/12/25 Vue.js
[02:12]Dota 2 推出全新英雄—— 电炎绝手
2019/08/23 DOTA
Python中使用glob和rmtree删除目录子目录及所有文件的例子
2014/11/21 Python
搞笑的程序猿:看看你是哪种Python程序员
2015/06/12 Python
Python编程中对super函数的正确理解和用法解析
2016/07/02 Python
使用python将请求的requests headers参数格式化方法
2019/01/02 Python
python腾讯语音合成实现过程解析
2019/08/01 Python
python 两个数据库postgresql对比
2019/10/21 Python
python Django 反向访问器的外键冲突解决
2020/05/20 Python
python类共享变量操作
2020/09/03 Python
美国玛丽莎收藏奢华时尚商店:Marissa Collections
2016/11/21 全球购物
全球性的在线购物网站:Zapals
2017/03/22 全球购物
TIME时代杂志台湾总代理:台时亚洲
2018/10/22 全球购物
车贷收入证明范本
2014/01/09 职场文书
初婚未育未抱养证明
2014/01/12 职场文书
总经理司机职责
2014/02/02 职场文书
采购类个人求职的自我评价
2014/02/18 职场文书
工作经历证明书范文
2014/11/02 职场文书
爱心捐款活动总结
2015/05/09 职场文书
处罚决定书范文
2015/06/24 职场文书
巧用 -webkit-box-reflect 倒影实现各类动效(小结)
2021/04/22 HTML / CSS
不负正版帝国之名 《重返帝国》引领SLG手游制作新的标杆
2022/04/07 其他游戏