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创建模块及模块导入的方法
May 27 Python
python 调用HBase的简单实例
Dec 18 Python
matplotlib中legend位置调整解析
Dec 19 Python
Python快速查找list中相同部分的方法
Jun 27 Python
Python3模拟curl发送post请求操作示例
May 03 Python
在django中图片上传的格式校验及大小方法
Jul 28 Python
pytorch 准备、训练和测试自己的图片数据的方法
Jan 10 Python
python re模块匹配贪婪和非贪婪模式详解
Feb 11 Python
PYcharm 激活方法(推荐)
Mar 23 Python
如何通过安装HomeBrew来安装Python3
Dec 23 Python
Spy++的使用方法及下载教程
Jan 29 Python
python使用pycharm安装pyqt5以及相关配置
Apr 22 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根据isbn书号查询amazon网站上的图书信息的示例
2014/02/13 PHP
PHP中应该避免使用同名变量(拆分临时变量)
2015/04/03 PHP
PHP使用mysql与mysqli连接Mysql数据库用法示例
2016/07/07 PHP
ThinkPHP5.1框架页面跳转及修改跳转页面模版示例
2019/05/06 PHP
php实现多站点共用session实现单点登录的方法详解
2019/09/18 PHP
javascript 全等号运算符使用说明
2010/05/31 Javascript
jQuery学习笔记之jQuery的动画
2010/12/22 Javascript
jQuery之自动完成组件的深入解析
2013/06/19 Javascript
js中的this关键字详解
2013/09/25 Javascript
超精准的javascript验证身份证号的具体实现方法
2015/11/18 Javascript
JavaScript实现简单Tip提示框效果
2016/04/20 Javascript
Node.js的Web模板引擎ejs的入门使用教程
2016/06/06 Javascript
浅谈jQuery中的eq()与DOM中element.[]的区别
2016/10/28 Javascript
3种不同的ContextMenu右键菜单实现代码
2016/11/03 Javascript
JS二叉树的简单实现方法示例
2017/04/05 Javascript
使用重写url机制实现验证码换一张功能
2017/08/01 Javascript
写给小白看的JavaScript异步
2017/11/29 Javascript
nodejs简单实现TCP服务器端和客户端的聊天功能示例
2018/01/04 NodeJs
js设计模式之单例模式原理与用法详解
2019/08/15 Javascript
layer.open提交子页面的form和layedit文本编辑内容的方法
2019/09/27 Javascript
Ant Design Pro 下实现文件下载的实现代码
2019/12/03 Javascript
Jquery $.map使用方法实例详解
2020/09/01 jQuery
一起来了解一下JavaScript的预编译(小结)
2021/03/01 Javascript
[06:04]DOTA2国际邀请赛纪录片:Just For LGD
2013/08/11 DOTA
利用Python实现kNN算法的代码
2019/08/16 Python
Anaconda详细安装步骤图文教程
2020/11/12 Python
连卡佛中国官网:Lane Crawford中文站
2018/01/27 全球购物
奥地利领先的在线药房:SHOP APOTHEKE
2019/10/07 全球购物
澳大利亚领先的亚麻品牌:Bed Threads
2019/12/16 全球购物
英国时尚首饰品牌:Missoma
2020/06/29 全球购物
八年级数学教学反思
2014/01/31 职场文书
热爱祖国演讲稿
2014/05/04 职场文书
2014年反腐倡廉工作总结
2014/12/05 职场文书
党员思想汇报材料
2014/12/19 职场文书
旅游安全责任协议书
2016/03/22 职场文书
工作自我评价范文
2019/03/21 职场文书