一、死锁问题

  1. 例子
import threading

import time

​

lock_1 = threading.Lock()

lock_2 = threading.Lock()

​

def func_1():

    print("func_1 starting......")

    lock_1.acquire()#我先占上lock_1

    print("func_1 申请了 lock_1.....")

    time.sleep(2)#必须得等一下啊,让这这两个函数形成死锁

    print("func_1 等待lock_2......")

    lock_2.acquire()

    print("func_1 申请了lock_2")

    lock_2.release()

    print("func_1 释放了 lock_2")

    lock_1.release()

    print("func_1 释放了 lock_1")

​

    print("func_1 done")

​

def func_2():

    print("func_2 staring......")

    lock_2.acquire()#我先占上lock_2

    print("func_2申请了lock_2.....")

    time.sleep(4)

    print("func_2等待lock_1.......")

    lock_1.acquire()

    print("func_2申请了lock_1.....")

    lock_1.release()

    print("func_2 释放了 lock_1")

    lock_2.release()

    print("func_2 释放了 lock_2")

​

    print("func_2 done")

​

if __name__ == "__main__":

    t1 = threading.Thread(target=func_1,args=())

    t2 = threading.Thread(target=func_2,args=())

​

    t1.start()

    t2.start()

​

    t1.join()

    t2.join()

2.解决方式

我们加入判断语句,对申请不到的锁就不申请了,直接走下去

关注里面的rst = lock_4.acquire(timeout=-1)#可见这是一个返回值是布尔类型的变量,timeout代表超时跳

lock_3 = threading.Lock()

lock_4 = threading.Lock()

​

def func_3():

    print("func_3 starting.....")

    lock_3.acquire(timeout=-1)

    print("func_3 申请了lock_3.....")

    time.sleep(2)

    print("func_3 等待lock_4.......")

​

    rst = lock_4.acquire(timeout=-1)#可见这是一个返回值是布尔类型的变量,timeout代表超时跳出

    if rst:

        print("func_3的带了锁lock_4")

        lock_4.release()

        print("func_3释放了lock_4")

    else:

        print("func_3没申请到lock_4")

​

    lock_3.release()

    print("func_3释放了lock_3")

​

    print("func_3 done......")

​

​

def func_4():

    print("func_4 starting.....")

    lock_4.acquire(timeout=4)

    print("func_4 申请了lock_4.....")

    time.sleep(2)

    print("func_4 等待lock_3.......")

​

    rst = lock_3.acquire(timeout=2)

    if rst:

        print("func_3得到了了锁lock_3")

        lock_3.release()

        print("func_4释放了lock_3")

    else:

        print("func_4没申请到lock_3")

​

    lock_4.release()

    print("func_4释放了lock_4")

​

    print("func_4 done......")

​

if __name__ == "__main__":

​

    t3 = threading.Thread(target=func_3,args=())

    t4 = threading.Thread(target=func_4,args=())

​

    t3.start()

    t4.start()

​

    t3.join()

    t4.join()

解决了冲突,但是实际上没有解决这个死锁问题,但是这已经足够,本就应该避免出现这种问题

二、源码

d25_3_dead_lock.py

https://github.com/ruigege66/Python_learning/blob/master/d25_3_dead_lock.py

2.CSDN:https://blog.csdn.net/weixin_44630050(心悦君兮君不知-睿)

3.博客园:https://www.cnblogs.com/ruigege0000/

4.欢迎关注微信公众号:傅里叶变换,后台回复”礼包“,获取大数据学习资料

Python连载35-死锁问题以及解决方式的更多相关文章

  1. python——报错ImportError:DLL load failed with error code -1073741795的解决方式

    python中导入一个包,import cv2总是报错'ImportError:DLL load failed with error code -1073741795',报错形式: 网上找了好久的解决 ...

  2. 【python系列】python画报表(Chartkick、Flask)(附中文乱码解决方式)

    chartkick 能够画 javascript 报表, 并且比較美观.可是网上搜了下.非常难找到 python 版本号的,于是查了些资料,摸索了下. 对 Flask 也不非常熟悉,这里就仅仅抛砖引玉 ...

  3. NAT的全然分析及其UDP穿透的全然解决方式

    NAT的全然分析及其UDP穿透的全然解决方式   一:基本术语 防火墙 防火墙限制了私网与公网的通信,它主要是将(防火墙)觉得未经授权的的包丢弃,防火墙仅仅是检验包的数据,并不改动数据包中的IP地址和 ...

  4. ubuntu下编译时遇到的错误及解决方式

    1.错误展示: hangma@ubuntu:~/test/test/protest/stack_test$ gcc  -c my_stack.c -o my_stack.o In file inclu ...

  5. 转:python idle 清屏问题的解决

    http://www.cnblogs.com/maybego/p/3234055.html python idle 清屏问题的解决 在学习和使用python的过程中,少不了要与python idle打 ...

  6. python输出htmltestrunner中文乱码如何解决

    python unittest要产生一个可看的报告,需要借助一个第三方的包 下载HTMLTestRunner.py 第三方库 ,参考地址: http://tungwaiyip.info/softwar ...

  7. Circular dependency issuse on cocoapods version(0.36.0) 全然解决方式(非降版本号)

    此前的文章中.以前提到在cocoapods依赖管理版本号假设超过0.34.4.比方0.35, 0.36.0等版本号中. 运行"pod install" 或者 "pod u ...

  8. 通过py2exe打包python程序的过程中,解决的一系列问题

    py2exe的使用方法参考<py2exe使用方法>. 注:程序可以在解释器中正常运行,一切问题都出在打包过程中. 问题1: 现象:RuntimeError: maximum recursi ...

  9. mixare的measureText方法在频繁调用时抛出“referencetable overflow max 1024”的解决方式

    这几天在搞基于位置的AR应用,採用了github上两款开源项目: mixare android-argument-reality-framework 这两个项目实现机制大致同样.我选取的是androi ...

随机推荐

  1. 《Scalable IO in Java》译文

    <Scalable IO in Java> 是java.util.concurrent包的作者,大师Doug Lea关于分析与构建可伸缩的高性能IO服务的一篇经典文章,在文章中Doug L ...

  2. Apache和Spring提供的StopWatch执行时间监视器

    相关阅读 [小家java]java5新特性(简述十大新特性) 重要一跃 [小家java]java6新特性(简述十大新特性) 鸡肋升级 [小家java]java7新特性(简述八大新特性) 不温不火 [小 ...

  3. 了解下Java中的Serializable

      在项目中也写了不少的JavaBean,也知道大多的JavaBean都实现了Serializable接口,也知道它的作用是序列化,序列化就是保存,反序列化就是读取.主要体现在这两方面: 1.存储.将 ...

  4. JavaOOP 第二章继承

    一 继承的概念 继承是java面向对象编程技术的一块基石,因为它允许创建分等级层次的类. 继承就是子类继承父类的特征和行为,使得子类对象(实例)具有父类的实例域和方法,或子类从父类继承方法,使得子类具 ...

  5. 【iOS】Signing for "project_name" requires a development team. Select a development team in the project editor

    Xcode 8.3.2 运行 GitHub 上下载的代码时报了这个错. 解决方法: 单击工程名 --> Signing --> Team --> 选择对应的Account(如果没有A ...

  6. WIN10安装VC6.0无法使用的解决办法

    WIN10安装VC6.0无法使用的解决办法 VC6.0确实已经太老了 VC6.0实在是很久以前的开发工具了,现在的win10已经对该软件不兼容,但是为了能使抱着怀旧情节的初学者们能像教科书或老前辈们一 ...

  7. Ubuntu中修改默认开机项

    1首先,按住Ctrl+Alt+t打开终端 2输入cd /etc/default 3输入sudo sudo nano grub 并按照提示输入密码 4在我们开机的时候,可以看到自己想要默认的开机项是多少 ...

  8. JVM(二):画骨

    ### 概述 我们首先来认识一下`JVM`的运行时数据区域,如果说`JVM`是一个人,那么运行时数据区域就是这个人的骨架,它支撑着JVM的运行,所以我们先来学习一下运行时数据区域的分类和简单介绍. # ...

  9. WPF ContextMenu+VisualTreeHelper实现删除控件操作

    <UserControl  MouseRightButtonDown="UserControl_MouseRightButtonDown" >    <UserC ...

  10. Python pip包管理器安装第三方库超时解决方案

    一.国内镜像安装 使用方法:pip install --index 镜像网站 第三方库名 二.镜像网站 http://pypi.douban.com/simple/ 豆瓣 http://mirrors ...