Python Threading 线程/互斥锁/死锁/GIL锁
导入线程包
import threading
准备函数线程,传参数
t1 = threading.Thread(target=func,args=(args,))
类继承线程,创建线程对象
class MyThread(threading.Thread) def run(self): pass if __name__ == "__main__": t = MyThread() t.start()
线程共享全面变量,但在共享全局变量时会出现数据错误问题
使用 threading 模块中的 Lock 类,添加互斥锁可以解决线程共享全局变量问题
# 创建锁 mutex = threading.Lock() # 锁定 mutex.acquire() # 释放锁 mutex.release()
互斥锁可能导致死锁问题
在线程间共享多个资源的时候,如果两个线程分别占有一部分资源,并且同时在等待对方的资源时,就会造成死锁.
解决方案:
1.银行家算法:程序设计时想好锁定与释放的时空关系
2.添加超时等待
Python 中 多线程的 GIL 全局解释器锁
GIL是C语言版本python解释器的遗留问题
GIL锁使得python中同一时刻其实只有一个线程在运行
但是多线程毕竟还是闭单线程快,这是因为在一个线程IO阻塞的时间段,其他线程可以运行
GIL 锁和互斥锁是不一样的,GIL锁是锁线程的,互斥锁是锁线程內事务的,互斥锁是开发者自己写的,GIL锁来源与C版本python解释器
解决GIL的方法
1.使用java版的python解释器
2.使用其他语言代码,完成该部分
总结
以上所述是小编给大家介绍的Python Threading 线程/互斥锁/死锁/GIL锁,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
相关文章
使用pandas或numpy处理数据中的空值(np.isnan()/pd.isnull())
这篇文章主要介绍了使用pandas或numpy处理数据中的空值(np.isnan()/pd.isnull()),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-05-05python sklearn与pandas实现缺失值数据预处理流程详解
对于缺失值的处理,主要配合使用sklearn.impute中的SimpleImputer类、pandas、numpy。其中由于pandas对于数据探索、分析和探查的支持较为良好,因此围绕pandas的缺失值处理较为常用2022-09-09vim自动补全插件YouCompleteMe(YCM)安装过程解析
这篇文章主要介绍了vim自动补全插件YouCompleteMe(YCM)安装过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2019-10-10python socket网络编程步骤详解(socket套接字使用)
这篇文章主要介绍了什么是套接字、PYTHON套接字模块,提供一个简单的python socket编程,大家参考使用2013-12-12
最新评论