总结
本文介绍了解决死锁的 2 种方案:
- 第 1 种顺序锁:通过改变获取锁的顺序也就打破“环路请求条件”来避免死锁问题的发生;
- 第 2 种轮询锁:通过轮询的方式也就是打破“请求和拥有条件”来解决死锁问题。它的实现思路是,通过自旋的方式来尝试获取锁,在获取锁的途中,如果有任何一个锁获取失败,则释放之前获取的所有锁,等待一段时间之后再次执行之前的流程,这样就避免一个锁一直被(一个线程)占用的尴尬了,从而避免了死锁问题。
参考 & 鸣谢
《Java并发编程实战》
原创并发文章推荐
14.SimpleDateFormat线程不安全的5种解决方案!15.synchronized 加锁 this 和 class 的区别!16.synchronized 优化手段之锁膨胀机制!17.synchronized 中的 4 个优化,你知道几个?18.ReentrantLock 中的 4 个坑!19.图解:为什么非公平锁的性能更高?