对于python中GIL的一些理解与代码实现
2022/6/4 1:22:26
本文主要是介绍对于python中GIL的一些理解与代码实现,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
近期看了一些关于GIL的一些内容,敲一下代码看看效果。
# coding:utf-8 # GIL(Global Interpreter Lock):他只允许任何时刻只有一个线程处于执行状态,即使是在具有多个CPU内核的多线程架构中。 # 为什么没有删除GIL,因为现在的python已经严重依赖GIL提供的解决方案。如果删除会破坏现有的C扩展。(free threading 就是删除的案例,他会导致单线程任务速度降低40%。) # 释放GIL:以前版本是采用计数策略删除,如果该线程计数为0,则删除。现在采用固定时间间隔,到了时间点就删除。 import time from threading import Thread from multiprocessing import Pool Count = 50000000 def countdown(n): while n>0: n-=1 if __name__ == "__main__": # 不采用多进程和多线程 start1 = time.time() countdown(Count) end1 = time.time() print("2:", end1 - start1) # 2.538 # 采用多线程 # t1 = Thread(target=countdown, args=(Count // 2,)) # t2 = Thread(target=countdown, args=(Count // 2,)) # start = time.time() # t1.start() # t2.start() # t1.join() # 这个方法主要是为了阻塞当前线程 # t2.join() # 至于为什么,我觉得可能是为了防止同一时刻有多个线程访问资源。 # end = time.time() # print("1:", end - start) # 2.717 # 采用多进程 # pool = Pool(processes=2) # start2 = time.time() # r1 = pool.apply_async(countdown, [Count//2]) # r2 = pool.apply_async(countdown, [Count//2]) # pool.close() # pool.join() # end2 = time.time() # print("3:",end2-start2) # 1.617
结果发现,采用多进程的确会好点。
这篇关于对于python中GIL的一些理解与代码实现的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-21Python编程基础教程
- 2024-11-20Python编程基础与实践
- 2024-11-20Python编程基础与高级应用
- 2024-11-19Python 基础编程教程
- 2024-11-19Python基础入门教程
- 2024-11-17在FastAPI项目中添加一个生产级别的数据库——本地环境搭建指南
- 2024-11-16`PyMuPDF4LLM`:提取PDF数据的神器
- 2024-11-16四种数据科学Web界面框架快速对比:Rio、Reflex、Streamlit和Plotly Dash
- 2024-11-14获取参数学习:Python编程入门教程
- 2024-11-14Python编程基础入门