python中GIL的原理
- 更新时间:2021-07-02 09:46:15
- 编辑:弓芸茗
参考资料
- Python程序设计 PDF 电子书 / 17.9 MB / 约翰·策勒 推荐度:
- Python高手之路 PDF 电子书 / 157.8 MB / 朱利安·丹乔 推荐度:
- 《零基础学Python(第2版)》视频,例题源代码 配套资源 / 38.3 MB / 黄传祿 张克强 赵越 推荐度:
- Python程序开发 PDF 电子书 / 65.7 MB / 罗大伟 李洪建 推荐度:
- 机器学习:Python实践 PDF 电子书 / 124.7 MB / 魏贞原 推荐度:
正文内容
给学习python的读者整理一篇《python中GIL的原理》优秀文章,技术要点讲的很好,增加了更多实例内容,希望对网友有用。
1、说明
GIL规定一个Python解释程序只能同时由一个线程控制。
在CPU限制类型和多线程代码中,GIL是一个性能瓶颈。
GIL使Python多线程成为伪并行多线程。
仅CPython解释器上存在GIL。
2、原理
(1)线程1、2、3轮流执行,每一个线程在执行是,都会锁住GIL,以阻止别的线程执行;
同样的,每一个线程执行一段后,会释放GIL,以允许别的线程开始利用资源。
(2)由于古老GIL机制,如果线程2需要在CPU2上执行,它需要先等待在CPU1上执行的线程1释放GIL(记住:GIL是全局的)
(3)如果线程1是因为 i/o 阻塞让出的GIL,那么线程2必定拿到GIL。但如果线程1是因为timer ticks计数满100ticks(大概对应了1000个bytecodes)让出GIL,那么这个时候线程1和线程2公平竞争。
(4)但要命的是,在Python 2.x, 线程1不会动态的调整自身的优先级,所以很大概率下次被选中执行的还是线程1,在很多个这样的选举周期内,线程2只能安静的看着线程1拿着GIL在CPU 1上欢快的执行。
(5)极端一点的情况下,比如线程1使用了while True在CPU1上执行,那就真是“一核有难,八核围观”了。
以上就是python中GIL的原理介绍,希望能对大家有所帮助。更多Python学习指路:
本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。
相关教程
-
Python做简单的字符串匹配详解
这篇文章主要介绍了Python做简单的字符串匹配详解的相关资料,需要的朋友可以参考下
发布时间:2019-08-26
-
利用Python网络爬虫爬取各大音乐评论的代码
给网友朋友们带来一篇关于Python的教程,这篇文章主要介绍了如何用Python网络爬虫爬取网易云音乐评论,文章用代码详细的示范了如何爬取网易云音乐评论,对正在学习的小伙伴有参考价值,需要的朋友可以参考下
发布时间:2022-10-09