千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  應聘面試  >  Java面試題  > java面試題:介紹一下ReentrantLock

java面試題:介紹一下ReentrantLock

來源:千鋒教育
發(fā)布人:wjy
時間: 2022-07-18 17:25:00 1658136300

  介紹一下ReentrantLock

  一、 ReentrantLock簡介

  ReentantLock 繼承接口 Lock 并實現(xiàn)了接口中定義的方法,他是一種可重入鎖,除了能完成 synchronized 所能完成的所有工作外,還提供了諸如可響應中斷鎖、可輪詢鎖請求、定時鎖等避免多線程死鎖的方法。

介紹一下ReentrantLock

  二、 Lock接口的主要方法

  1.void lock(): 執(zhí)行此方法時, 如果鎖處于空閑狀態(tài), 當前線程將獲取到鎖. 相反, 如果鎖已經(jīng)被其他線程持有, 將禁用當前線程, 直到當前線程獲取到鎖。

  2.boolean tryLock():如果鎖可用, 則獲取鎖, 并立即返回 true, 否則返回 false. 該方法和 lock()的區(qū)別在于, tryLock()只是"試圖"獲取鎖, 如果鎖不可用, 不會導致當前線程被禁用, 當前線程仍然繼續(xù)往下執(zhí)行代碼. 而 lock()方法則是一定要獲取到鎖, 如果鎖不可用, 就一直等待, 在未獲得鎖之前,當前線程并不繼續(xù)向下執(zhí)行.

  3.void unlock():執(zhí)行此方法時, 當前線程將釋放持有的鎖. 鎖只能由持有者釋放, 如果線程并不持有鎖, 卻執(zhí)行該方法, 可能導致異常的發(fā)生.

  4.Condition newCondition():條件對象,獲取等待通知組件。該組件和當前的鎖綁定,當前線程只有獲取了鎖,才能調(diào)用該組件的 await()方法,而調(diào)用后,當前線程將縮放鎖。

  5.getHoldCount() :查詢當前線程保持此鎖的次數(shù),也就是執(zhí)行此線程執(zhí)行l(wèi)ock方法的次數(shù)。

  6.getQueueLength():返回正等待獲取此鎖的線程估計數(shù),比如啟動 10 個線程,1 個線程獲得鎖,此時返回的是 9。

  7.getWaitQueueLength:(Condition condition)返回等待與此鎖相關(guān)的給定條件的線程估計數(shù)。比如 10 個線程,用同一個 condition 對象,并且此時這 10 個線程都執(zhí)行了 condition 對象的 await 方法,那么此時執(zhí)行此方法返回 10。

  8.hasWaiters(Condition condition):查詢是否有線程等待與此鎖有關(guān)的給定條件 (condition),對于指定 contidion 對象,有多少線程執(zhí)行了 condition.await 方法。

  9.hasQueuedThread(Thread thread):查詢給定線程是否等待獲取此鎖。

  10.hasQueuedThreads():是否有線程等待此鎖。

  11.isFair():該鎖是否公平鎖。

  12.isHeldByCurrentThread(): 當前線程是否保持鎖鎖定,線程的執(zhí)行 lock 方法的前后分別是 false 和 true。

  13.isLock():此鎖是否有任意線程占用。

  14.lockInterruptibly():如果當前線程未被中斷,獲取鎖。

  15.tryLock():嘗試獲得鎖,僅在調(diào)用時鎖未被線程占用,獲得鎖。

  16.tryLock(long timeout TimeUnit unit):如果鎖在給定等待時間內(nèi)沒有被另一個線程保持,則獲取該鎖。

  更多關(guān)于“Java培訓”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓經(jīng)驗,課程大綱更科學更專業(yè),有針對零基礎(chǔ)的就業(yè)班,有針對想提升技術(shù)的好程序員班,高品質(zhì)課程助力你實現(xiàn)java程序員夢想。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學 138****2860 剛剛成功領(lǐng)取
王同學 131****2015 剛剛成功領(lǐng)取
張同學 133****4652 剛剛成功領(lǐng)取
李同學 135****8607 剛剛成功領(lǐng)取
楊同學 132****5667 剛剛成功領(lǐng)取
岳同學 134****6652 剛剛成功領(lǐng)取
梁同學 157****2950 剛剛成功領(lǐng)取
劉同學 189****1015 剛剛成功領(lǐng)取
張同學 155****4678 剛剛成功領(lǐng)取
鄒同學 139****2907 剛剛成功領(lǐng)取
董同學 138****2867 剛剛成功領(lǐng)取
周同學 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
面向?qū)ο缶幊痰奶卣魇鞘裁?請解釋每個特征

答案:面向?qū)ο缶幊痰奶卣靼ǎ悍庋b(Encapsulation):封裝是將相關(guān)的數(shù)據(jù)和方法組合在一起形成類的機制。它可以隱藏內(nèi)部實現(xiàn)細節(jié),只暴露必要的...詳情>>

2023-07-18 13:56:00
容器是什么?如何理解容器

  容器(Container)是一個廣泛的概念,指的是一種可以容納其他元素或?qū)ο蟮臄?shù)據(jù)結(jié)構(gòu)或抽象概念。在計算機科學中,容器的概念經(jīng)常出現(xiàn)在數(shù)據(jù)結(jié)...詳情>>

2023-05-08 13:41:00