Python 死锁(笔记总结)

#死锁
'''


开发过程中使用线程,在线程间共享多个资源的时候,
如果两个线程分别占有一部分资源并且同时等待对方的资源,就会造成死锁。
尽管死锁很少发生,但一旦发生就会造成应用的停止响应,程序不做任何事情。

避免死锁:
解决:
1.重构代码
2.添加超时释放锁
'''

from threading import Thread,Lock
import sys
import time

lockA = Lock()
lockB = Lock()

#自定义线程
class MyThread1(Thread):
    #不论进程还是线程重写的都是run方法
    def run(self):
        if lockA.acquire():#如果可以获取到锁则返回True
            print(self.name +'A锁')
            time.sleep(0.1)
            if lockB.acquire(timeout=3):#在acquire函数中阻塞,一直等待锁,不能往下运行了
                                        #如果加上超时则表示退出acquire,继续往下执行把a锁释放了
                print(self.name +"A锁+B锁")
                lockB.release()
            lockA.release()

#自定义线程
class MyThread2(Thread):
    #不论进程还是线程重写的都是run方法
    def run(self):
        if lockB.acquire():#如果可以获取到锁则返回True
            print(self.name +'B锁')
            time.sleep(0.1)
            if lockA.acquire(timeout=3):
                print(self.name +"A锁+B锁")
                lockA.release()
            lockB.release()


def main():
    pass

if __name__ == "__main__":

#若不加上超时,则会一直不能进入A锁+B锁情况。
#造成线程1,2一直死等
    MyThread1().start()
    MyThread2().start()

    sys.exit(int(main() or 0))

猜你喜欢

转载自blog.csdn.net/weixin_44291381/article/details/114312569
今日推荐