多線程死鎖在java程序員筆試的時候時有遇見,死鎖概念在之前的文章有介紹,大家應該也都明白它的概念,不清楚的去翻看歷史文章吧。
下面是一個多線程死鎖的例子
輸出
thread1 get lock1
thread2 get lock2
兩個線程相互得到鎖1,鎖2,然后線程1等待線程2釋放鎖2,線程2等待線程1釋放鎖1,兩者各不相互,這樣形成死鎖。
那么如何避免和解決死鎖問題呢?
1、按順序加鎖
上個例子線程間加鎖的順序各不一致,導致死鎖,如果每個線程都按同一個的加鎖順序這樣就不會出現死鎖。
2、獲取鎖時限
每個獲取鎖的時候加上個時限,如果超過某個時間就放棄獲取鎖之類的。
3、死鎖檢測
按線程間獲取鎖的關系檢測線程間是否發生死鎖,如果發生死鎖就執行一定的策略,如終斷線程或回滾操作等。
推薦去我的博客閱讀更多:
2.Spring MVC、Spring Boot、Spring Cloud 系列教程
3.Maven、Git、Eclipse、Intellij IDEA 系列工具教程
覺得不錯,別忘了點贊+轉發哦!