一個多線程死鎖案例,如何避免及解決死鎖問題?


多線程死鎖在java程序員筆試的時候時有遇見,死鎖概念在之前的文章有介紹,大家應該也都明白它的概念,不清楚的去翻看歷史文章吧。

下面是一個多線程死鎖的例子

輸出

thread1 get lock1

thread2 get lock2

兩個線程相互得到鎖1,鎖2,然后線程1等待線程2釋放鎖2,線程2等待線程1釋放鎖1,兩者各不相互,這樣形成死鎖。

那么如何避免和解決死鎖問題呢?

1、按順序加鎖

上個例子線程間加鎖的順序各不一致,導致死鎖,如果每個線程都按同一個的加鎖順序這樣就不會出現死鎖。

2、獲取鎖時限

每個獲取鎖的時候加上個時限,如果超過某個時間就放棄獲取鎖之類的。

3、死鎖檢測

按線程間獲取鎖的關系檢測線程間是否發生死鎖,如果發生死鎖就執行一定的策略,如終斷線程或回滾操作等。

推薦去我的博客閱讀更多:

1.Java JVM、集合、多線程、新特性系列教程

2.Spring MVC、Spring Boot、Spring Cloud 系列教程

3.Maven、Git、Eclipse、Intellij IDEA 系列工具教程

4.Java、后端、架構、阿里巴巴等大廠最新面試題

覺得不錯,別忘了點贊+轉發哦!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM