Python-线程-死锁

# coding=utf-8
import threading
import time

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


class MyThread1(threading.Thread):
    def run(self):
        if mutexA.acquire():  # 上锁
            print(self.name + '----do1---up----')
            time.sleep(1)

            if mutexB.acquire():  # 等待对方释放锁,然后上锁
                print(self.name + '----do1---down----')
                mutexB.release()
            mutexA.release()


class MyThread2(threading.Thread):
    def run(self):
        if mutexB.acquire():  # 上锁
            print(self.name + '----do2---up----')
            time.sleep(1)
            if mutexA.acquire():  # 等待对方释放锁,然后上锁
                print(self.name + '----do2---down----')
                mutexA.release()
            mutexB.release()


mutexA = threading.Lock()
mutexB = threading.Lock()

if __name__ == '__main__':
    t1 = MyThread1()
    t2 = MyThread2()
    t1.start()
    t2.start()

运行结果:

Thread-1----do1—up----
Thread-2----do2—up----

猜你喜欢

转载自blog.csdn.net/weixin_44151971/article/details/85231595
今日推荐