造成死锁的原因有如下几条(需同时满足条件):
1、互斥条件:任务使用的资源中至少有一个是不能共享的,资源的使用和释放方法都使用了synchronized 关键字修饰
2、至少有一个任务它必须持有一个资源,并且这个任务正在等待获取另一个当前正在被别的任务持有的资源
3、资源不能被项目抢占,任务必须把资源释放当做普通事件,资源只能被释放后才能被其他任务获取到
4、必须有循环等待,这时一个任务等待其他任务释放资源,其他任务又在等待另一个任务释放资源,且直到最后有一个任务在等待第一个任务释放资源,使得大家都被锁住,就造成了死锁
那如何避免死锁的情况发生:
1、加锁顺序,线程按照一定的顺序枷锁
2、加锁时限,线程尝试获取锁的时候加上一定的时限,超过时限则放弃对该锁的请求,并主动释放自己已经占有的锁,可以考虑使用lock.trylock(timeout)来代替使用内部锁机制
3、避免一个线程同时获取多个锁
4、避免一个线程在锁内同时占用多个资源
5、对于数据库锁,加锁和解锁必须在一个数据库连接里,否则有可能出现解锁失败的情况