您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關Java多線程之多種鎖和阻塞隊列的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
顧名思義,就是很樂觀,每次去拿數據的時候都認為別人不會修改,所以不會上鎖,但是在更新的時候會判斷一下在此期間別人有沒有去更新這個數據,可以使用版本號等機制。
樂觀鎖適用于多讀的應用類型,樂觀鎖在Java中是通過使用無鎖編程來實現,最常采用的是CAS算法,Java原子類中的遞增操作就通過CAS自旋實現的。
CAS全稱 Compare And Swap(比較與交換),是一種無鎖算法。在不使用鎖(沒有線程被阻塞)的情況下實現多線程之間的變量同步。java.util.concurrent包中的原子類就是通過CAS來實現了樂觀鎖。
總是假設最壞的情況,每次去拿數據的時候都認為別人會修改,所以每次在拿數據的時候都會上鎖,這樣別人想拿這個數據就會阻塞直到它拿到鎖。
先看官網的解釋翻譯后的
看不太懂,那么我們結合一下下面的案例就行了。
兩個同步方法01和02,都是被鎖住的,當我們運行01的時候,一旦獲取的01的鎖,那么02的鎖也可以被自動獲取。
補充:lock和unlock只要配對使用,就不會有問題。
其實CAS底層就是用 Unsafe類+CAS(自旋) 實現的,CAS底層有一個do while語句,循環比較在主存中的值是否等于期望值。
讀歸讀,寫歸寫,讀和寫可以同時進行。
隊列中放著數據,一個線程生產,一個線程獲取。
阻塞隊列有多少實現類呢?
感謝各位的閱讀!關于“Java多線程之多種鎖和阻塞隊列的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。