Java中的CountDownLatch簡單理解
一、什么是CountDownLatch
CountDownLatch是一個同步工具類,用來攜調(diào)多個線程之間的同步,它是是使用一個計數(shù)器進行實現(xiàn)的,計數(shù)器初始值為線程數(shù)量。
當(dāng)每一個線程完成自己任務(wù)后,計數(shù)器的值就會減1。
當(dāng)計數(shù)器的值為0時,表示所有的線程都已經(jīng)完成一些任務(wù),然后再CountDownLatch上等待的線程就可以恢復(fù)執(zhí)行下來的任務(wù)。
二、哪些場景使用CountDownLatch
使用場景
- 某個線程需要在其他n個線程執(zhí)行完畢后再往下執(zhí)行。將CountDownLatch的計算器初始化化為new CountDownLatch(n),每當(dāng)一個線程任務(wù)執(zhí)行完畢,就將計數(shù)器減一(countDownLatch.countDown()),當(dāng)計數(shù)器變?yōu)?的時候,在CountDownLatch上的線程就會被喚醒 。比如,啟動一個服務(wù)時,主線程要等待多個組件加載完畢,之后在繼續(xù)執(zhí)行。
- 多個線程并行執(zhí)行同一個任務(wù),提高響應(yīng)速度。注意時并行,不是并發(fā),強調(diào)的是多個線程在某一時刻同時開始執(zhí)行。類似于賽跑,將多個線程放到起點,等待起跑,然后同時開跑。做法是初始化一個共享的CountDownLatch(1),將其計數(shù)器初始化為1,多個線程在開始執(zhí)行任務(wù)前首先countDownLatch.await(),當(dāng)主線程調(diào)用countDown()時,計數(shù)器為0,多個線程同時被喚醒。
三、CountDownLatch常用的方法
- new CountDownLatch(int count):count為計數(shù)器的初始值(一般需要多少個先吃執(zhí)行,count就設(shè)置為幾)
- countDown():每調(diào)用一次計數(shù)器值-1,直到count被減為0,代表所有線程全部執(zhí)行完畢。
- getCount():獲取當(dāng)前的計數(shù)器值。
- await():等待計數(shù)器變?yōu)?,即等待所有的異步線程執(zhí)行完畢
- boolean await(long timeout,TimeUnit unit):此方法至多會等待指定的時間,然后超時會自動喚醒,若timeout小于等于0,則不會等待。當(dāng)計數(shù)器變?yōu)?,則返回true。若指定的等待時間過去了,則返回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();
//初始化線程運行的數(shù)量
CountDownLatch countDownLatch = new CountDownLatch(poolNum);
Map<Integer,Integer> map = new HashMap<>();
for (int i = 1; i <= poolNum; i++) {
//耗時
Integer time = i*1000;
ThreadPoolUtils.execute(()->{
try {
//假設(shè)邏輯執(zhí)行的耗時
Thread.sleep(time);
map.put(time,time);
} catch (InterruptedException e) {
e.printStackTrace();
}finally {
countDownLatch.countDown();
}
});
}
countDownLatch.await();
System.out.println("總耗時:"+(System.currentTimeMillis()-start));
for (Integer key: map.keySet()){
//打印出來的key值是沒有順序的,因為競爭的CPU資源不一樣
System.out.println("map的key為:"+key+" map的值為:"+ map.get(key));
}
}
}到此這篇關(guān)于Java中的CountDownLatch簡單理解的文章就介紹到這了,更多相關(guān)CountDownLatch簡單理解內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring Boot集成Swagger2項目實戰(zhàn)
在日常的工作中,我們往往需要給前端(WEB端、IOS、Android)或者第三方提供接口,這個時候我們就需要給他們提供一份詳細的API說明文檔。這篇文章我們就來分享一種API文檔維護的方式,即通過Swagger來自動生成Restuful API文檔2018-01-01
關(guān)于Assert.assertEquals報錯的問題及解決
這篇文章主要介紹了關(guān)于Assert.assertEquals報錯的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05
SpringMvc+POI處理excel表數(shù)據(jù)導(dǎo)入
這篇文章主要為大家詳細介紹了SpringMvc+POI處理excel表數(shù)據(jù)導(dǎo)入,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06

