当前位置: 移动技术网 > IT编程>脚本编程>Python > Python Threading 线程/互斥锁/死锁/GIL锁

Python Threading 线程/互斥锁/死锁/GIL锁

2019年07月21日  | 移动技术网IT编程  | 我要评论

我的名字叫金三顺下载,猪猪侠之棒棒糖大战,莱州市人事网

导入线程包

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.使用其他语言代码,完成该部分

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网