介紹一下ReentrantLock
一、 ReentrantLock簡(jiǎn)介
ReentantLock 繼承接口 Lock 并實(shí)現(xiàn)了接口中定義的方法,他是一種可重入鎖,除了能完成 synchronized 所能完成的所有工作外,還提供了諸如可響應(yīng)中斷鎖、可輪詢(xún)鎖請(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() :查詢(xún)當(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):查詢(xún)是否有線程等待與此鎖有關(guān)的給定條件 (condition),對(duì)于指定 contidion 對(duì)象,有多少線程執(zhí)行了 condition.await 方法。
9.hasQueuedThread(Thread thread):查詢(xún)給定線程是否等待獲取此鎖。
10.hasQueuedThreads():是否有線程等待此鎖。
11.isFair():該鎖是否公平鎖。
12.isHeldByCurrentThread(): 當(dāng)前線程是否保持鎖鎖定,線程的執(zhí)行 lock 方法的前后分別是 false 和 true。
13.isLock():此鎖是否有任意線程占用。
14.lockInterruptibly():如果當(dāng)前線程未被中斷,獲取鎖。
15.tryLock():嘗試獲得鎖,僅在調(diào)用時(shí)鎖未被線程占用,獲得鎖。
16.tryLock(long timeout TimeUnit unit):如果鎖在給定等待時(shí)間內(nèi)沒(méi)有被另一個(gè)線程保持,則獲取該鎖。
更多關(guān)于“Java培訓(xùn)”的問(wèn)題,歡迎咨詢(xún)千鋒教育在線名師。千鋒已有十余年的培訓(xùn)經(jīng)驗(yàn),課程大綱更科學(xué)更專(zhuān)業(yè),有針對(duì)零基礎(chǔ)的就業(yè)班,有針對(duì)想提升技術(shù)的好程序員班,高品質(zhì)課程助力你實(shí)現(xiàn)java程序員夢(mèng)想。