欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中的CountDownLatch簡單理解

 更新時(shí)間:2024年01月17日 09:57:14   作者:java-zh  
這篇文章主要介紹了Java中的CountDownLatch簡單理解,CountDownLatch是一個同步工具類,用來攜調(diào)多個線程之間的同步,它是是使用一個計(jì)數(shù)器進(jìn)行實(shí)現(xiàn)的,計(jì)數(shù)器初始值為線程數(shù)量,需要的朋友可以參考下

一、什么是CountDownLatch

CountDownLatch是一個同步工具類,用來攜調(diào)多個線程之間的同步,它是是使用一個計(jì)數(shù)器進(jìn)行實(shí)現(xiàn)的,計(jì)數(shù)器初始值為線程數(shù)量。

當(dāng)每一個線程完成自己任務(wù)后,計(jì)數(shù)器的值就會減1。

當(dāng)計(jì)數(shù)器的值為0時(shí),表示所有的線程都已經(jīng)完成一些任務(wù),然后再CountDownLatch上等待的線程就可以恢復(fù)執(zhí)行下來的任務(wù)。

二、哪些場景使用CountDownLatch

使用場景

  1. 某個線程需要在其他n個線程執(zhí)行完畢后再往下執(zhí)行。將CountDownLatch的計(jì)算器初始化化為new CountDownLatch(n),每當(dāng)一個線程任務(wù)執(zhí)行完畢,就將計(jì)數(shù)器減一(countDownLatch.countDown()),當(dāng)計(jì)數(shù)器變?yōu)?的時(shí)候,在CountDownLatch上的線程就會被喚醒 。比如,啟動一個服務(wù)時(shí),主線程要等待多個組件加載完畢,之后在繼續(xù)執(zhí)行。
  2. 多個線程并行執(zhí)行同一個任務(wù),提高響應(yīng)速度。注意時(shí)并行,不是并發(fā),強(qiáng)調(diào)的是多個線程在某一時(shí)刻同時(shí)開始執(zhí)行。類似于賽跑,將多個線程放到起點(diǎn),等待起跑,然后同時(shí)開跑。做法是初始化一個共享的CountDownLatch(1),將其計(jì)數(shù)器初始化為1,多個線程在開始執(zhí)行任務(wù)前首先countDownLatch.await(),當(dāng)主線程調(diào)用countDown()時(shí),計(jì)數(shù)器為0,多個線程同時(shí)被喚醒。

三、CountDownLatch常用的方法

  • new CountDownLatch(int count):count為計(jì)數(shù)器的初始值(一般需要多少個先吃執(zhí)行,count就設(shè)置為幾)
  • countDown():每調(diào)用一次計(jì)數(shù)器值-1,直到count被減為0,代表所有線程全部執(zhí)行完畢。
  • getCount():獲取當(dāng)前的計(jì)數(shù)器值。
  • await():等待計(jì)數(shù)器變?yōu)?,即等待所有的異步線程執(zhí)行完畢
  • boolean await(long timeout,TimeUnit unit):此方法至多會等待指定的時(shí)間,然后超時(shí)會自動喚醒,若timeout小于等于0,則不會等待。當(dāng)計(jì)數(shù)器變?yōu)?,則返回true。若指定的等待時(shí)間過去了,則返回false。

四、CountDownLatch使用案例

線程池+CountDownLatch

public class Test {
    public static void main(String[] args) throws InterruptedException {
        //當(dāng)前執(zhí)行的線程數(shù)量
        Integer poolNum = 10;
        long start = System.currentTimeMillis();
        //初始化線程運(yùn)行的數(shù)量
        CountDownLatch countDownLatch = new CountDownLatch(poolNum);
        Map<Integer,Integer> map = new HashMap<>();
        for (int i = 1; i <= poolNum; i++) {
            //耗時(shí)
            Integer time = i*1000;
            ThreadPoolUtils.execute(()->{
                try {
                    //假設(shè)邏輯執(zhí)行的耗時(shí)
                    Thread.sleep(time);
                    map.put(time,time);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }finally {
                    countDownLatch.countDown();
                }
            });
        }
        countDownLatch.await();
        System.out.println("總耗時(shí):"+(System.currentTimeMillis()-start));
        for (Integer key: map.keySet()){
            //打印出來的key值是沒有順序的,因?yàn)楦偁幍腃PU資源不一樣
            System.out.println("map的key為:"+key+" map的值為:"+ map.get(key));
        }
    }
}

到此這篇關(guān)于Java中的CountDownLatch簡單理解的文章就介紹到這了,更多相關(guān)CountDownLatch簡單理解內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳細(xì)總結(jié)IDEA中打jar包的兩種方式

    詳細(xì)總結(jié)IDEA中打jar包的兩種方式

    發(fā)現(xiàn)有很多小伙伴都不會用IDEA打jar包,今天給大家詳細(xì)總結(jié)了兩種IDEA打jar包的方式,對正在學(xué)習(xí)IDEA使用的小伙伴很有幫助,需要的朋友可以參考下
    2021-05-05
  • Java循環(huán)隊(duì)列原理與用法詳解

    Java循環(huán)隊(duì)列原理與用法詳解

    這篇文章主要介紹了Java循環(huán)隊(duì)列原理與用法,結(jié)合實(shí)例形式詳細(xì)分析了Java循環(huán)隊(duì)列基本概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下
    2020-03-03
  • java并發(fā)無鎖多線程單線程示例詳解

    java并發(fā)無鎖多線程單線程示例詳解

    這篇文章主要為大家介紹了java并發(fā)無鎖多線程單線程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • Spring Boot集成Swagger2項(xiàng)目實(shí)戰(zhàn)

    Spring Boot集成Swagger2項(xiàng)目實(shí)戰(zhàn)

    在日常的工作中,我們往往需要給前端(WEB端、IOS、Android)或者第三方提供接口,這個時(shí)候我們就需要給他們提供一份詳細(xì)的API說明文檔。這篇文章我們就來分享一種API文檔維護(hù)的方式,即通過Swagger來自動生成Restuful API文檔
    2018-01-01
  • SpringBoot配置SLF4J日志全過程

    SpringBoot配置SLF4J日志全過程

    這篇文章主要介紹了SpringBoot配置SLF4J日志全過程,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • java自定義序列化的具體使用

    java自定義序列化的具體使用

    本文主要介紹了java自定義序列化的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • 關(guān)于Assert.assertEquals報(bào)錯的問題及解決

    關(guān)于Assert.assertEquals報(bào)錯的問題及解決

    這篇文章主要介紹了關(guān)于Assert.assertEquals報(bào)錯的問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • SpringMvc+POI處理excel表數(shù)據(jù)導(dǎo)入

    SpringMvc+POI處理excel表數(shù)據(jù)導(dǎo)入

    這篇文章主要為大家詳細(xì)介紹了SpringMvc+POI處理excel表數(shù)據(jù)導(dǎo)入,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • 解決JDK版本沖突顯示問題(雙版本沖突)

    解決JDK版本沖突顯示問題(雙版本沖突)

    這篇文章主要介紹了解決JDK版本沖突顯示問題(雙版本沖突),具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • 一文搞懂Java中的反射機(jī)制

    一文搞懂Java中的反射機(jī)制

    這篇文章主要介紹了Java中反射機(jī)制的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-08-08

最新評論