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!
推薦閱讀:
- Java面試題沖刺第二十四天–並發編程
- 一文秒懂Java中的樂觀鎖 VS 悲觀鎖
- 深入理解 CAS 算法原理已經在jdk中的運用
- 詳細分析Java內存模型
- 一文帶你搞懂Java中Synchronized和Lock的原理與使用