死锁?

https://www.cnblogs.com/hadoop-dev/p/6899171.html

1.什么是死锁?

死锁就是两个线程或者以上占用了对方所需的资源,导致这些线程处于等待状态,无法继续执行。如果是两个线程互相持有对方所需的资源,此时造成死锁。

死锁产生的条件:

(1)互斥条件:一个资源只能被一个线程同时占用。

(2)请求和保持条件:如果一个线程请求的资源被占用的话,那么该线程目前所占用的资源也不会释放。

(3)不剥夺条件:资源未被释放时,别的线程不能进行剥夺占用。

(4)循环等待条件:当发生死锁时,所有等待的线程必定想成一个死循环,一直等待。

2.递归死锁

直接调用:A-A

间接调用:A-B-A

虽然递归可以让代码简洁,但是多线程使用递归会容易造成死锁问题。

3.锁难以避免,如何加锁。

加锁顺序;加锁时限;死锁检测;

加锁顺序需要提前知道,不能全部保证;

加锁时限控制好的话,基本上不会耽误;

死锁检测有回退机制,可以设置死锁的优先级等。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值