久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

        手機(jī)站
        千鋒教育

        千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

        千鋒教育

        掃一掃進(jìn)入千鋒手機(jī)站

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

        關(guān)注千鋒學(xué)習(xí)站小程序
        隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

        當(dāng)前位置:首頁  >  應(yīng)聘面試  >  Java面試題  > 介紹一下ReentrantLock

        介紹一下ReentrantLock

        來源:千鋒教育
        發(fā)布人:wjy
        時(shí)間: 2022-11-19 17:27:00 1668850020

          一. 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ā)生;

        介紹一下ReentrantLock

          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è)線程保持,則獲取該鎖。

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

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

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

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

        2023-05-08 13:41:00
        科技| 丘北县| 清河县| 姚安县| 遂平县| 广安市| 永春县| 铜陵市| 宜宾县| 缙云县| 昌都县| 泰安市| 巩留县| 合肥市| 桐乡市| 宁陵县| 上杭县| 苍溪县| 伽师县| 达日县| 寻甸| 庄浪县| 乌兰浩特市| 青龙| 晋城| 铁力市| 天水市| 灵山县| 鄂托克前旗| 肥西县| 松滋市| 宣汉县| 汉沽区| 金寨县| 米脂县| 阿拉善右旗| 罗城| 仙桃市| 德安县| 新龙县| 芦山县|