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