多线程学习笔记(三)死锁
一、什么是死锁?
线程死锁描述的是这样一种情况:多个线程同时被阻塞,他们中的一个或者全部都在等待某个资源被释放。由于线程无限期地阻塞,因此程序不可能正常终止。
二、产生死锁的条件
- 互斥条件:该资源任意一个时刻只由一个线程占用。
- 请求与保持条件:一个线程因请求资源而阻塞时,对已获得的资源保持不放。
- 不剥夺条件: 线程已获得的资源在末使用完之前不能被其他线程强行剥夺,只有自己使用完毕后才释放资源。
- 循环等待条件: 若干进程之间形成一种头尾相接的循环等待资源关系。
三、怎么避免死锁
- 破坏互斥条件 :这个条件我们没有办法破坏,因为我们用锁本来就是想让他们互斥的(临界资源需要互斥访问)。
- 破坏请求与保持条件 :一次性申请所有的资源。
- 破坏不剥夺条件 :占用部分资源的线程进一步申请其他资源时,如果申请不到,可以主动释放它占有的资源。
- 破坏循环等待条件 :靠按序申请资源来预防。按某一顺序申请资源,释放资源则反序释放。破坏循环等待条件。
避免死锁常见的几个方法:
1)避免一个线程同时获取多个锁。
2)避免一个线程在所内同时占用多个资源,尽量保证每个锁只占用一个资源。
3)尝试使用定时锁,使用lock.tryLock(timeout)来替代使用内部锁机制。
4)对于数据库锁,加锁和解锁必须在一个数据库连接里,否则会出现解锁失败的情况、

浙公网安备 33010602011771号