https://www.cnblogs.com/hadoop-dev/p/6899171.html
1.什么是死锁?
死锁就是两个线程或者以上占用了对方所需的资源,导致这些线程处于等待状态,无法继续执行。如果是两个线程互相持有对方所需的资源,此时造成死锁。
死锁产生的条件:
(1)互斥条件:一个资源只能被一个线程同时占用。
(2)请求和保持条件:如果一个线程请求的资源被占用的话,那么该线程目前所占用的资源也不会释放。
(3)不剥夺条件:资源未被释放时,别的线程不能进行剥夺占用。
(4)循环等待条件:当发生死锁时,所有等待的线程必定想成一个死循环,一直等待。
2.递归死锁
直接调用:A-A
间接调用:A-B-A
虽然递归可以让代码简洁,但是多线程使用递归会容易造成死锁问题。
3.锁难以避免,如何加锁。
加锁顺序;加锁时限;死锁检测;
加锁顺序需要提前知道,不能全部保证;
加锁时限控制好的话,基本上不会耽误;
死锁检测有回退机制,可以设置死锁的优先级等。