Python Threading 线程/互斥锁/死锁/GIL锁
程序员文章站
2022-05-29 10:06:01
导入线程包 准备函数线程,传参数 类继承线程,创建线程对象 线程共享全面变量,但在共享全局变量时会出现数据错误问题使用 threading 模块中的 Lock 类,添加互斥锁可以解决线程共享全局变量问题 互斥锁可能导致死锁问题在线程间共享多个资源的时候,如果两个线程分别占有一部分资源,并且同时在等待 ......
导入线程包
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.使用其他语言代码,完成该部分
下一篇: Jedis的配置和优化
推荐阅读
-
举例讲解Python中的死锁、可重入锁和互斥锁
-
Python多线程编程(四):使用Lock互斥锁
-
python多线程threading.Lock锁用法实例
-
对python多线程中互斥锁Threading.Lock的简单应用详解
-
举例讲解Python中的死锁、可重入锁和互斥锁
-
Python Threading 线程/互斥锁/死锁/GIL锁
-
python之GIL全局锁(全局锁的目的是为了让线程更加安全)
-
Python多线程编程(四):使用Lock互斥锁
-
Python中threading库实现线程锁与释放锁
-
python 之 并发编程(守护线程与守护进程的区别、线程互斥锁、死锁现象与递归锁、信号量、GIL全局解释器锁)