线程死锁是指两个或者多个线程互相持有对方所需要的资源,导致这些线程处于等待状态,无法前往执行。当线程进入对象的synchronized代码块时,便占有了资源,直到它退出该代码块或者调用wait方法,才释放资源,再次期间,其他线程不能进入该代码块。当线程互相持有对方所需要的资源,会互相等待对方释放资源,如果线程都不主动释放所占有的资源,就会产生死锁。
产生死锁的四个条件:
- 互斥条件:进程对于所分配的资源具有排它性:即一个资源只能被一个进程占用,直到该进程释放
- 请求和保持条件:一个进程因请求被占用资源而发生堵塞时,对已经获得的资源保持不放。
- 不剥夺条件:任何一个资源在没被该进程释放之前,任何进程都无法对他剥夺占用
- 循环等待条件:当发生死锁时,所等待的进程必定会行程一个环路(类似死循环),造成永久堵塞。
避免死锁
- 按同一顺序访问对象
- 避免事物中的用户交互
- 保持事务简短并处于一个处理中
- 使用较低的隔离级别
- 使用基于行版本控制的隔离级别
- 使用绑定连接