python 之死锁递归锁

递归锁案例:

from threading import Thread,Lock,RLock
import time

#死锁
# mutexA=Lock()
# mutexB=Lock()

mutexB=mutexA=RLock() #递归锁可以连续acquire()


class Mythread(Thread):
    def run(self):
        self.f1()
        self.f2()

    def f1(self):
        mutexA.acquire()
        print('%s 抢到了A锁' %self.name)

        mutexB.acquire()
        print('%s 抢到了B锁' %self.name)
        mutexB.release()

        mutexA.release()

    def f2(self):
        mutexB.acquire()
        print('%s 抢到了B锁' %self.name)
        time.sleep(1)

        mutexA.acquire()
        print('%s 抢到了A锁' %self.name)
        mutexA.release()

        mutexB.release()


if __name__ == '__main__':
    for i in range(10):
        t=Mythread()
        t.start()

  

posted @ 2018-06-25 16:55  cyh追梦寻  阅读(69)  评论(0)    收藏  举报