一. ReentrantLock簡(jiǎn)介
ReentantLock繼承接口Lock并實(shí)現(xiàn)了接口中定義的方法,他是一種可重入鎖,除了能完成synchronized所能完成的所有工作外,還提供了諸如可響應(yīng)中斷鎖、可輪詢鎖請(qǐng)求、定時(shí)鎖等避免多線程死鎖的方法。
二. Lock接口的主要方法
1. void lock(): 執(zhí)行此方法時(shí),如果鎖處于空閑狀態(tài),當(dāng)前線程將獲取到鎖。相反,如果鎖已經(jīng)被其他線程持有,將禁用當(dāng)前線程,直到當(dāng)前線程獲取到鎖。
2. boolean tryLock():如果鎖可用,則獲取鎖,并立即返回 true,否則返回 false. 該方法和 lock()的區(qū)別在于,tryLock()只是"試圖"獲取鎖, 如果鎖不可用, 不會(huì)導(dǎo)致當(dāng)前線程被禁用,當(dāng)前線程仍然繼續(xù)往下執(zhí)行代碼。而 lock()方法則是一定要獲取到鎖,如果鎖不可用,就一直等待,在未獲得鎖之前,當(dāng)前線程并不繼續(xù)向下執(zhí)行;
3. void unlock():執(zhí)行此方法時(shí), 當(dāng)前線程將釋放持有的鎖. 鎖只能由持有者釋放, 如果線程并不持有鎖, 卻執(zhí)行該方法, 可能導(dǎo)致異常的發(fā)生;
4. Condition newCondition():條件對(duì)象,獲取等待通知組件。該組件和當(dāng)前的鎖綁定, 當(dāng)前線程只有獲取了鎖,才能調(diào)用該組件的 await()方法,而調(diào)用后,當(dāng)前線程將縮放鎖;
5. getHoldCount() :查詢當(dāng)前線程保持此鎖的次數(shù),也就是執(zhí)行此線程執(zhí)行l(wèi)ock方法的次數(shù);
6. getQueueLength():返回正等待獲取此鎖的線程估計(jì)數(shù),比如啟動(dòng)10個(gè)線程,1個(gè)線程獲得鎖,此時(shí)返回的是9;
7. getWaitQueueLength:(Condition condition)返回等待與此鎖相關(guān)的給定條件的線程估計(jì)數(shù)。比如 10 個(gè)線程,用同一個(gè)condition對(duì)象,并且此時(shí)這10個(gè)線程都執(zhí)行了condition對(duì)象的await方法,那么此時(shí)執(zhí)行此方法返回10;
8. hasWaiters(Condition condition):查詢是否有線程等待與此鎖有關(guān)的給定條件(condition),對(duì)于指定contidion對(duì)象,有多少線程執(zhí)行了condition.await方法;
9. hasQueuedThread(Thread thread):查詢給定線程是否等待獲取此鎖;
10. hasQueuedThreads():是否有線程等待此鎖;
11. isFair():該鎖是否公平鎖;
12. isHeldByCurrentThread(): 當(dāng)前線程是否保持鎖鎖定,線程的執(zhí)行l(wèi)ock方法的前后分別是false和 true;
13. isLock():此鎖是否有任意線程占用;
14. lockInterruptibly():如果當(dāng)前線程未被中斷,獲取鎖;
15. tryLock():嘗試獲得鎖,僅在調(diào)用時(shí)鎖未被線程占用,獲得鎖;
16. tryLock(long timeout TimeUnit unit):如果鎖在給定等待時(shí)間內(nèi)沒有被另一個(gè)線程保持,則獲取該鎖。