死锁是指两个或多个线程因互相等待对方持有的资源而无限阻塞的现象;其发生需同时满足互斥、占有并等待、不可抢占和循环等待四个条件;可通过按序加锁、超时机制、减少锁嵌套及jstack排查来预防。
线程锁死(也叫死锁,Deadlock)是指两个或多个线程在执行过程中,因争夺资源而造成的一种互相等待的现象,导致这些线程都无法继续执行下去。
什么是死锁?
当一组线程中的每一个都在等待另一个线程持有的资源时,就会发生死锁。这种情况下,所有涉及的线程都会被阻塞,程序无法向前推进。
举个常见例子:
- 线程A持有锁1,并尝试获取锁2
- 线程B持有锁2,并尝试获取锁1
- 结果:A等B释放锁2,B等A释放锁1 —— 谁也不让,陷入僵局
产生死锁的四个必要条件
只有当以下四个条件同时满足时,才会发生死锁:
- 互斥条件:资源一次只能被一个线程占用
- 占有并等待:线程已持有至少一个资源,但又申请新的资源,而该资源被其他线程占有
- 不可抢占:已分配给线程的资源不能被强制剥夺,只能由线程自行释放
- 循环等待:存在一个线程的循环链,每个线程都在等待下一个线程所占有的资源
如何避免或解决死锁?
虽然Java本身不会自动检测和解除死锁,但可以通过编程手段预防:
- 按固定顺序获取锁:确保所有线程以相同的顺序申请多个锁,打破循环等待
- 使用超时机制:通过tryLock(timeout)尝试获取锁,超时则放弃,避免无限等待
- 尽量减少锁的嵌套:降低多锁协作的复杂度
- 使用工具排查:利用jstack命令查看线程堆栈,识别死锁线程
基本上就









