Java并發(fā)工具之CountDownLatch使用詳解
1、使用場景
通過使用 CountDownLatch可以使當前線程阻塞,等待其他線程完成給定任務??梢灶惐嚷糜螆F導游要等待所有的游客到齊后才能去下一個景點。
CountDownLatch 主要應用場景:一個線程等待多個線程完成給定任務后,然后執(zhí)行后續(xù)的操作的場景。
2、使用介紹
CountDownLatch的構(gòu)造函數(shù)接收一個int類型的參數(shù)作為計數(shù)器,如果你想等待N個點完 成,這里就傳入N。
這里所說的N個 點,可以是N個線程,也可以是1個線程里的N個執(zhí)行步驟。CountDownLatch構(gòu)造函數(shù)如下:
public CountDownLatch(int count) { if (count < 0) throw new IllegalArgumentException("count < 0"); this.sync = new Sync(count); }
計數(shù)器參數(shù)count必須大于等于0,等于0的時候,調(diào)用await方法時不會 阻塞當前線程。
當我們調(diào)用CountDownLatch的countDown()方法時,N就會減1,CountDownLatch的await()方法 會阻塞當前線程,直到N變成零。
CountDownLatch 方法
- await() 阻塞當前線程,直到計數(shù)器為零為止;
- await(long timeout, TimeUnit unit) await()的重載方法,可以指定阻塞時長;
- countDown() 計數(shù)器減1,如果計數(shù)達到零,釋放所有等待的線程。
- getCount() 返回當前計數(shù)
3、使用案例
使用多線程下載網(wǎng)絡上圖片,現(xiàn)在完成后,提示用戶下載完成。
public class DownLoadWorker implements Runnable{ private String url; private CountDownLatch countDownLatch; public DownLoadWorker(String url, CountDownLatch countDownLatch) { this.url = url; this.countDownLatch = countDownLatch; } @Override public void run() { //省略無數(shù)業(yè)務代碼 System.out.println("線程" + Thread.currentThread().getName() + "開始下載完成"); countDownLatch.countDown(); } } public static void main(String[] args) throws InterruptedException { CountDownLatch countDownLatch=new CountDownLatch(5); //使用Stream 生成5個線程 List<Thread> workers = Stream .generate(() -> new Thread(new DownLoadWorker("https://image.baidu.com/", countDownLatch))) .limit(5) .collect(toList()); //運行線程 workers.forEach(Thread::start); //等待線程完成 countDownLatch.await(); System.out.println("圖片已下載完~~~"); }
4、 Thread.join()和CountDownLatch的區(qū)別
Thread.join()是Thread類的一個方法,Thread.join()的實現(xiàn)是依靠Object的wait()和notifyAll()來完成的,而CountDownLatch是JUC包中的一個工具類。
當我們使用ExecutorService ,就不能使用join,必須使用CountDownLatch比如:
ExecutorService service = Executors.newFixedThreadPool(5); final CountDownLatch latch = new CountDownLatch(5); for(int x = 0; x < 5; x++) { service.submit(new Runnable() { public void run() { // do something latch.countDown(); } }); } latch.await();
調(diào)用join方法需要等待thread執(zhí)行完畢才能繼續(xù)向下執(zhí)行,而CountDownLatch只需要檢查計數(shù)器的值為零就可以繼續(xù)向下執(zhí)行,相比之下,CountDownLatch更加靈活一些,可以實現(xiàn)一些更加復雜的業(yè)務場景。
到此這篇關(guān)于Java并發(fā)工具之CountDownLatch使用詳解的文章就介紹到這了,更多相關(guān)CountDownLatch的使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring Boot配置特定屬性spring.profiles的方法
這篇文章主要介紹了Spring Boot配置特定屬性spring.profiles的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-11-11Java畢業(yè)設計實戰(zhàn)之圖片展覽館管理系統(tǒng)的實現(xiàn)
這是一個使用了java+Springboot+SpringMVC+JPA+Jsp+maven+mysql開發(fā)的圖片展覽館管理系統(tǒng),是一個畢業(yè)設計的實戰(zhàn)練習,具有圖片展覽管理該有的所有功能,感興趣的朋友快來看看吧2022-01-01javafx tableview鼠標觸發(fā)更新屬性詳解
這篇文章主要為大家詳細介紹了javafx tableview鼠標觸發(fā)更新屬性的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08Springboot內(nèi)外部logback多環(huán)境配置詳解
本文主要介紹了Springboot內(nèi)外部logback多環(huán)境配置詳解,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01