死锁产生原因:两个或两个以上的线程抢占同一个共享资源,导致互相等待的一个现象;再没有外部干涉的情况下线程会一致出现阻塞状态无法往下执行。
产生死锁必须满足以下四个条件:
1.互斥条件:资源只能被一个线程占有
2.请求和保持状态:a线程已经获得x资源,在等待y资源时没有释放x资源。
3.不可抢占条件:其他线程不能去抢占线程中已经获得的资源
4.循环等待:a线程等待b线程的资源,b线程等待a线程的资源
解决方案:
1.通过jstack命令导出线程的dump日志,定位到具体的死锁代码;通过修改代码去破坏四个条件的任意一个就可以完成,除互斥条件因为锁的本身就满足互斥条件。