zoukankan      html  css  js  c++  java
  • 死锁和递归锁

    from threading import Thread, Lock, RLock
    import time
    
    '''
    Rlock锁 也被称之为递归锁
    第一个抢到Rlock锁的人,可以连续使用acquire,release
    每acquire一次,锁身上计数加1
    每release一次,锁身上计数减1
    等锁身上的计数为0时,其他人就可以抢锁
    '''
    # mutexA = Lock()
    # mutexB = Lock()
    mutexA = mutexB = RLock()
    
    
    class MyThead(Thread):
        def run(self):  # 创建线程时,会自动执行run方法
            self.func1()
            self.func2()
    
        def func1(self):
            mutexA.acquire()
            print('%s 抢到了A锁' % self.name)
            mutexB.acquire()
            print('%s 抢到了B锁' % self.name)
            mutexB.release()
            print('%s 释放了B锁' % self.name)
            mutexA.release()
            print('%s 释放了A锁' % self.name)
    
        def func2(self):
            mutexB.acquire()
            print('%s 抢到了B锁' % self.name)
            time.sleep(1)
            mutexA.acquire()
            print('%s 抢到了A锁' % self.name)
            mutexA.release()
            print('%s 释放了A锁' % self.name)
            mutexB.release()
            print('%s 释放了B锁' % self.name)
    
    
    for i in range(10):
        p = MyThead()
        p.start()
    
    # 自己千万不要轻易的处理锁的问题
  • 相关阅读:
    DataGridView设置不自动显示数据库中未绑定的列
    [转载]sed 简明教程
    FreeMarker template error!
    tomcat共享lib里面的jar包
    java命令
    实验报告四
    实验报告三
    实验报告二
    实验一
    网络对抗技术作业
  • 原文地址:https://www.cnblogs.com/asdaa/p/11353311.html
Copyright © 2011-2022 走看看