死锁是指两个或多个线程因互相等待对方持有的资源而无限阻塞的现象;其发生需同时满足互斥、占有并等待、不可抢占和循环等待四个条件;可通过按序加锁、超时机制、减少锁嵌套及jstack排查来预防。
线程锁死(也叫死锁,Deadlock)是指两个或多个线程在执行过程中,因争夺资源而造成的一种互相等待的现象,导致这些线程都无法继续执行下去。
当一组线程中的每一个都在等待另一个线程持有的资源时,就会发生死锁。这种情况下,所有涉及的线程都会被阻塞,程序无法向前推进。
举个常见例子:
只有当以下四个条件同时满足时,才会发生死锁:
虽然Java本身不会自动检测和解除死锁,但可以通过编程手段预防:
确保所有线程以相同的顺序申请多个锁,打破循环等待基本上就这些。死锁不是Java特有的问题,但在多线程编程中很常见,关键在于设计阶段就有意识地规避风险。