1、什么是死锁?
死锁是这样一种情形:多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放。由于线程被无限期地阻塞,因此程序不可能正常终止。
2、关于死锁的情况
2.1 一个线程一把锁,可重入锁没事。不可重入锁死锁
2.2 两个线程两把锁,即使是可重入锁也会死锁
2.3 N个线程,M把锁。此时线程和锁的数量更多了,更容易死锁!
3、死锁的四个必要条件(缺一不可)
(1)互斥使用:一个线程拿到一把锁之后,另一个线程不能使用(锁的基本特点)
(2)不可抢占:一个线程拿到锁,只能自己主动释放,其他线程无法强行占有(锁的基本特点)
(3)请求和保持:即当资源请求者在请求其他的资源的同时保持对原有资源的占有(代码的特点)
(4)循环等待:“家钥匙锁车里了,车钥匙锁家里了”形成了一个等待环路(代码的特点)
当上述四个条件都成立的时候,便形成死锁。当然,死锁的情况下如果打破上述任何一个条件,便可让死锁消失。
4、如何避免死锁
其中最简单有效的就是破坏循环等待~—> 针对锁进行编号,如果同时需要获取多把锁,约定加锁顺序,先对最小的编号加锁~
eg1:
eg2: