Java多線程產生死鎖的必要條件

今天小編就爲大家分享一篇關於Java多線程產生死鎖的必要條件,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

線程死鎖是指由於兩個或者多個線程互相持有對方所需要的資源,導致這些線程處於等待狀態,無法前往執行。當線程進入對象的synchronized代碼塊時,便佔有了資源,直到它退出該代碼塊或者調用wait方法,才釋放資源,在此期間,其他線程將不能進入該代碼塊。當線程互相持有對方所需要的資源時,會互相等待對方釋放資源,如果線程都不主動釋放所佔有的資源,將產生死鎖。

死鎖是操作系統裏裏面的一個重要的概念,死鎖通常發生在併發的場景裏。

死鎖是多個進程或線程,彼此爭搶資源而陷入僵局的一種情況。

在筆者參加的多次面試中,發現不少候選人雖然大概知道死鎖是一種因爲爭搶資源引起的問題,但真的要寫一個死鎖的例子的話,還是有不少候選人不知道該如何下手。

其實,真正理清楚了死鎖產生的必要的條件,寫出一個死鎖的例子並不困難。那麼,就java的多線程而言,產生死鎖有哪些必要條件呢?

  • 1,必須有2個或以上的線程。一個線程是不會產生死鎖的,它頂多產生等待。
  • 2,必須有2個臨界資源,即,必須有2個鎖。這也是死鎖產生的必要的條件。當只有一個臨界資源,或者說只有一個鎖時,當一個線程獲取了鎖,另一個線程雖然暫時無法獲取鎖,但它至多也就是需要進行等待。而不會陷入死鎖。
  • 3,兩個線程,每個線程都獲取了其中的一個鎖,但爲了完成工作,還需對方的另一個鎖。這種情況下,纔會產生死鎖。這種情況也稱爲循環等待。
  • 4,不可剝奪。

以上即爲死鎖產生的必要條件。

避免死鎖可以概括成三種方法:

  • 固定加鎖的順序(針對鎖順序死鎖)
  • 開放調用(針對對象之間協作造成的死鎖)
  • 使用定時鎖-->tryLock()

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對神馬文庫的支持。如果你想了解更多相關內容請查看下面相關鏈接

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章