Java多線程之多種鎖和阻塞隊列

一、悲觀鎖和樂觀鎖

1.1. 樂觀鎖

顧名思義,就是很樂觀,每次去拿數據的時候都認為別人不會修改,所以不會上鎖,但是在更新的時候會判斷一下在此期間別人有沒有去更新這個數據,可以使用版本號等機制。

樂觀鎖適用於多讀的應用類型,樂觀鎖在Java中是通過使用無鎖編程來實現,最常采用的是CAS算法,Java原子類中的遞增操作就通過CAS自旋實現的。

CAS全稱 Compare And Swap(比較與交換),是一種無鎖算法。在不使用鎖(沒有線程被阻塞)的情況下實現多線程之間的變量同步。java.util.concurrent包中的原子類就是通過CAS來實現瞭樂觀鎖。

1.2. 悲觀鎖

總是假設最壞的情況,每次去拿數據的時候都認為別人會修改,所以每次在拿數據的時候都會上鎖,這樣別人想拿這個數據就會阻塞直到它拿到鎖。

二、公平鎖和非公平鎖

在這裡插入圖片描述


在這裡插入圖片描述

三、可重入鎖(遞歸鎖)

先看官網的解釋翻譯後的

在這裡插入圖片描述

看不太懂,那麼我們結合一下下面的案例就行瞭。

在這裡插入圖片描述

兩個同步方法01和02,都是被鎖住的,當我們運行01的時候,一旦獲取的01的鎖,那麼02的鎖也可以被自動獲取。

在這裡插入圖片描述

補充:lock和unlock隻要配對使用,就不會有問題。

四、自旋鎖

在這裡插入圖片描述

其實CAS底層就是用 Unsafe類+CAS(自旋) 實現的,CAS底層有一個do while語句,循環比較在主存中的值是否等於期望值。

五、獨占鎖(寫)/共享鎖(讀)

在這裡插入圖片描述

讀歸讀,寫歸寫,讀和寫可以同時進行。

六、什麼是阻塞隊列?

隊列中放著數據,一個線程生產,一個線程獲取。

在這裡插入圖片描述
在這裡插入圖片描述

七、阻塞隊列(BlockingQueue)

在這裡插入圖片描述

阻塞隊列有多少實現類呢?

在這裡插入圖片描述

到此這篇關於Java多線程之多種鎖和阻塞隊列的文章就介紹到這瞭,更多相關java多種鎖和阻塞隊列內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: