• 关于python中的死锁


    死锁

    • 在线程间共享多个资源的时候,如果两个线程分别占有一部分资源并且同时等待对方的资源,就会造成死锁。

    例子

    from threading import Thread,Lock
    import time
    mutexA=Lock()
    mutexB=Lock()
    
    class MyThread(Thread):
        def run(self):
            self.func1()
            self.func2()
        def func1(self):
            mutexA.acquire()
            print('\033[41m%s 拿到A锁\033[0m' %self.name)
    
            mutexB.acquire()
            print('\033[42m%s 拿到B锁\033[0m' %self.name)
            mutexB.release()
    
            mutexA.release()
    
        def func2(self):
            mutexB.acquire()
            print('\033[43m%s 拿到B锁\033[0m' %self.name)
            time.sleep(2)
    
            mutexA.acquire()
            print('\033[44m%s 拿到A锁\033[0m' %self.name)
            mutexA.release()
    
            mutexB.release()
    
    if __name__ == '__main__':
        for i in range(5):
            t=MyThread()
            t.start()
    

    小故事分享

    从前有两个线程,它们分别叫线程1和线程2(假设没有其他线程跟它俩抢东西)

    1. 线程1先执行了func1的任务,所以线程1先分别拿到A锁和B锁,然后释放A锁和B锁,然后就去执行任务func2了,然后就先拿到了B锁,然后就累的睡着了
    2. 在线程1睡着的期间,线程2执行到了func1任务,刚拿到A锁,迫切的想再拿到B锁,这时发现B锁被其他线程占用了,线程2就得等线程1用完了,再轮到它用,于是它就等啊等……
    3. (two thousand years later)线程1醒了,发现自己手里的B锁,然后迫切的想拿到A锁,此时发现A锁在线程2的手里,没办法,它只能等线程2用完A锁再使用,所以它也等啊等啊……
    4. 就这样,线程1等着线程2的A锁,线程2等着线程1的B锁,就这样两个线程彼此等待着对方,不离不弃,海枯石烂……
      我凄美的爱情故事就这样讲完了,希望能从故事里得到点感悟
    世上只有10种人,一种懂二进制,一种不懂二进制
  • 相关阅读:
    nginx缓存
    java 常用命令工具
    shell流程控制--循环语句
    Python 文档 涉及词汇
    python 学习网站
    python web入门程序
    编译安装 Python3.6.1
    正则表达式与grep
    编译安装 Nginx1.12.1
    查看进程号
  • 原文地址:https://www.cnblogs.com/zlxuan/p/12925624.html
Copyright © 2020-2023  润新知