摘要:原文地址深入淺出之獨占鎖模式深入淺出之共享鎖模式深入淺出之條件隊列前面三篇文章如果之前沒有基礎的話看起來會比較吃力,這篇文章說明一下的基礎知識,方便快速了解。當前節點由于超時或者中斷被取消,節點進入這個狀態以后將保持不變。
之前分析了AQS中的獨占鎖,共享鎖,條件隊列三大模塊,現在從結構上來看看AQS各個組件的情況。
原文地址:http://www.jianshu.com/p/49b8...
深入淺出AQS之獨占鎖模式
深入淺出AQS之共享鎖模式
深入淺出AQS之條件隊列
前面三篇文章如果之前沒有AQS基礎的話看起來會比較吃力,這篇文章說明一下AQS的基礎知識,方便快速了解AQS。
首先AQS的基本執行過程就是嘗試獲取鎖,成功則返回,如果失敗就進入同步隊列進行鎖資源的等待?;谶@個流程可以看出隊列跟隊列中的節點應該是兩個重點。
首先來看下AQS里隊列節點Node的結構:
該類中有五個字段,依次來看一下:
prev,next:指向它的前置節點跟后繼節點,由此看出AQS中的同步隊列是個雙向鏈表。
thread:當前線程對象。
waitStatus:當前節點的狀態,是個int類型變量,依次有如下幾種:
值 | 類型 | 說明 |
---|---|---|
-1 | SIGNAL | 當前節點的后繼節點被阻塞,因此當當前節點在釋放或者取消的時候需要喚醒它的后繼節點。 |
1 | CANCELLED | 當前節點由于超時或者中斷被取消,節點進入這個狀態以后將保持不變。注:這是唯一大于0的值,很多判斷邏輯會用到這個特征 |
-2 | CONDITION | 當前節點正處在條件隊列中,在條件達成前不能獲取鎖。 |
-3 | PROPAGATE | 當前節點獲取到鎖的信息需要傳遞給后繼節點,共享鎖模式使用該值。 |
0 | 無 | 節點初始狀態。 |
nextWaiter:如果當前節點是共享模式,該值會指向一個SHARE節點。如果當前節點是在條件隊列中,則該值會指向下一個等待條件的節點。
了解了Node節點的數據結構以后,看下獨占鎖模式下的同步隊列的結構:
注:head節點是new出來一個新的Node節點,而tail是直接指向隊列中最后一個節點。
了解了獨占鎖模式隊列以后,看下共享鎖模式下的同步隊列(注意對比其中的不同):
注:共享鎖跟獨占鎖是同一個同步隊列,也就是說同步隊列中的節點既可以是共享類型也可以是獨占類型。
除了獨占鎖跟共享鎖使用的同步隊列,還有一個很重要的隊列就是條件隊列,一起看下:
注意區分條件隊列跟同步隊列的區別:1、頭尾指針,2、單鏈表
搞明白了AQS中這些基礎的數據結構以后,最后再看下AQS對外提供的API:
獨占鎖模式:
方法名 | 說明 |
---|---|
acquire | 獨占模式獲取鎖,不響應中斷,如果發生中斷只會把當前線程的中斷狀態設置為true |
acquireInterruptibly | 獨占模式獲取鎖,如果在獲取鎖的過程中線程被中斷,則直接拋出中斷異常 |
release | 釋放鎖資源 |
共享鎖模式:
方法名 | 說明 |
---|---|
acquireShared | 共享模式獲取鎖,不響應中斷,如果發生中斷只會把當前線程的中斷狀態設置為true |
acquireSharedInterruptibly | 共享模式獲取鎖,如果在獲取鎖的過程中線程被中斷,則直接拋出中斷異常 |
releaseShared | 釋放鎖資源 |
條件隊列:
方法名 | 說明 |
---|---|
await | 阻塞等待條件,如果被中斷則拋出中斷異常 |
awaitUninterruptibly | 阻塞等待條件,不響應中斷,如果發生中斷只會把線程中斷狀態設置為true |
awaitNanos | 等待納秒時間,如果被中斷則拋出中斷異常 |
awaitUntil | 等待直到一個截止時間,如果被中斷則拋出中斷異常 |
await(long time, TimeUnit unit) | 等待一個指定時間,如果被中斷則拋出中斷異常 |
signal | 喚醒等待隊列中的第一個節點 |
signalAll | 喚醒等待隊列中的所有節點 |
擴展API:
方法名 | 說明 |
---|---|
tryAcquire | 嘗試獲取獨占鎖,不阻塞 |
tryAcquireNanos | 嘗試在指定納秒時間內獲取獨占鎖,如果被中斷則拋出中斷異常 |
tryRelease | 嘗試釋放獨占鎖,不阻塞 |
tryAcquireShared | 嘗試獲取共享鎖,不阻塞 |
tryAcquireSharedNanos | 嘗試在指定納秒時間內獲取共享鎖,如果被中斷則拋出中斷異常 |
tryReleaseShared | 嘗試釋放共享鎖,不阻塞 |
了解了上面介紹的關于AQS的基礎數據結構及API以后,再去看我之前寫的三篇分別介紹獨占鎖,共享鎖,條件隊列實現原理的文章就不會云里霧里了。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/67753.html
摘要:從上面的代碼可以看出,條件隊列是建立在鎖基礎上的,而且必須是獨占鎖原因后面會通過源碼分析。明天就是國慶長假了,我自己也計劃出國玩一趟,散散心。提前祝廣大朋友國慶快樂。 相比于獨占鎖跟共享鎖,AbstractQueuedSynchronizer中的條件隊列可能被關注的并不是很多,但它在阻塞隊列的實現里起著至關重要的作用,同時如果想全面了解AQS,條件隊列也是必須要學習的。 原文地址:ht...
摘要:其二如果返回值等于表示當前線程獲取共享鎖成功,但它后續的線程是無法繼續獲取的,也就是不需要把它后面等待的節點喚醒。 在了解了AQS獨占鎖模式以后,接下來再來看看共享鎖的實現原理。 原文地址:http://www.jianshu.com/p/1161... 搞清楚AQS獨占鎖的實現原理之后,再看共享鎖的實現原理就會輕松很多。兩種鎖模式之間很多通用的地方本文只會簡單說明一下,就不在贅述了,...
摘要:獲取鎖的過程當線程調用申請獲取鎖資源,如果成功,則進入臨界區。如果隊列中有其他等待鎖資源的線程需要喚醒,則喚醒隊列中的第一個等待節點先入先出。釋放鎖時,如果隊列中有等待的線程就進行喚醒。 每一個Java工程師應該都或多或少了解過AQS,我自己也是前前后后,反反復復研究了很久,看了忘,忘了再看,每次都有不一樣的體會。這次趁著寫博客,打算重新拿出來系統的研究下它的源碼,總結成文章,便于以后...
摘要:簡介抽象隊列同步器,以下簡稱出現在中,由大師所創作。獲取成功則返回,獲取失敗,線程進入同步隊列等待。響應中斷版的超時響應中斷版的共享式獲取同步狀態,同一時刻可能會有多個線程獲得同步狀態。 1.簡介 AbstractQueuedSynchronizer (抽象隊列同步器,以下簡稱 AQS)出現在 JDK 1.5 中,由大師 Doug Lea 所創作。AQS 是很多同步器的基礎框架,比如 ...
摘要:簡介抽象隊列同步器,以下簡稱出現在中,由大師所創作。獲取成功則返回,獲取失敗,線程進入同步隊列等待。響應中斷版的超時響應中斷版的共享式獲取同步狀態,同一時刻可能會有多個線程獲得同步狀態。 1.簡介 AbstractQueuedSynchronizer (抽象隊列同步器,以下簡稱 AQS)出現在 JDK 1.5 中,由大師 Doug Lea 所創作。AQS 是很多同步器的基礎框架,比如 ...
閱讀 2502·2021-11-24 10:29
閱讀 2641·2021-09-24 09:48
閱讀 5747·2021-09-22 15:56
閱讀 3161·2021-09-06 15:00
閱讀 2675·2019-08-30 15:54
閱讀 747·2019-08-30 13:48
閱讀 2919·2019-08-30 11:17
閱讀 3425·2019-08-29 11:20