JUC併發系列(八):併發程式設計常用輔助類CountDownLatch與CyclicBarrier(手敲程式碼示例)
跑起一個程式,並不難;難的是,能讓程式跑多遠!—— 一顆剽悍的種子
JUC併發系列
JUC併發系列(一):什麼?聽說你搞混了併發和並行
JUC併發系列(二):詳解Condition實現精準通知喚醒
JUC併發系列(三):面試問併發,一問鎖就懵(怒肝一篇透徹理解鎖,面試不慌)
JUC併發系列(四):【面試常問】多種方法解決ArrayList非執行緒安全,詳解CopyOnWriteArrayList
JUC併發系列(五):CopyOnWriteArraySet解決HashSet非執行緒安全
JUC併發系列(六):ConcurrentHashMap解決HashMap非執行緒安全
JUC併發系列(七):觸及Callable
走進JUC併發程式設計中必經的三個常用輔助類,CountDownLatch、CyclicBarrier與Semaphore。CountDownLatch和CyclicBarrier可以拿來一起講,雖然不同,但彼此卻很相近。
一、什麼是 CountDownLatch?
CountDownLatch在jdk1.5被引入,是在java.util.cucurrent包下,允許一個或多個執行緒等待直到在其他執行緒中指向完畢的同步輔助。
可以簡單的理解作用:countDownLatch是等待其他執行緒執行完畢後再執行本身類的執行緒。
1.關鍵程式碼及原理
通過一個倒計數器實現,計數器初始值是執行緒數量。當一個執行緒執行完,計數器值-1,當計數器值為0表示所有執行緒執行完,最後等待的執行緒才可以恢復執行。
CountDownLatch裡的count引數是計數值,計數值不能大於所執行的執行緒數,否則滿足不了條件不再執行。
CountDownLatch(int count);
countDown 數量 -1
countDownLatch.countDown(); //數量-1
等待倒計數器為 0,再往下執行
countDownLatch.await();//等待倒計數器為0
2.手敲程式碼示例
public class Demo{
public static void main(String[] args) throws ExecutionException, InterruptedException {
Integer x = 5;
CountDownLatch countDownLatch = new CountDownLatch(x);
for (int i = 0; i < x; i++) {
new Thread(()->{
System.out.println(Thread.currentThread().getName());
countDownLatch.countDown();
}).start();
}
countDownLatch.await();
System.out.println("執行完畢");
}
}
3.執行結果
二、什麼是 CyclicBarrier?
其實你理解了CountDownLatch也就理解CyclicBarrier,上面的CountDownLatch是倒計數器,計數器的值是每次遞減,而CyclicBarrier是計數器,是每次遞增。前者可以說是在做減法,而後者是在做加法。這也是為什麼我會把這兩個關鍵字放在一起講的原因,有比較的學習,才會更加清晰。
2.手敲程式碼示例
public class Demo{
public static void main(String[] args) throws ExecutionException, InterruptedException {
Integer x = 5;
CyclicBarrier cyclicBarrier = new CyclicBarrier(x,()->{
System.out.println("執行完畢");
});
for (Integer i = 0; i <= x; i++) {
new Thread(()->{
System.out.println(Thread.currentThread().getName());
try {
cyclicBarrier.await();
} catch (InterruptedException e) {
e.printStackTrace();
} catch (BrokenBarrierException e) {
e.printStackTrace();
}
}).start();
}
}
}
3.執行結果
三、最後
最後的最後,為了更好的閱讀體驗,我把想說的話都放在了下面,嘿嘿。
我是一顆剽悍的種子 把我會的,認真的分享 是我寫部落格一直不變的信條。
如果你能看到這篇博文,說明我們們還是很有緣的;希望能帶給你一些許幫助,創作的不易, 把我文章的知識帶走,你的三連留下,點贊,評論,關注,是我最大的動力。
相關文章
- JUC併發程式設計之Semaphore、CountDownLatch、CyclicBarrier協同工具程式設計CountDownLatch
- JUC併發程式設計學習筆記(七)常用的輔助類程式設計筆記
- Java併發—— CountDownLatch與CyclicBarrierJavaCountDownLatch
- 突擊併發程式設計JUC系列-併發工具 Semaphore程式設計
- 併發程式設計之:CountDownLatch程式設計CountDownLatch
- java併發程式設計工具類JUC第八篇:ConcurrentHashMapJava程式設計HashMap
- 併發程式設計之:JUC併發控制工具程式設計
- 併發程式設計之 CyclicBarrier 原始碼分析程式設計原始碼
- Java 併發工具類 CountDownLatch、CyclicBarrier、Semaphore、ExchangerJavaCountDownLatch
- Java 併發程式設計(十四) -- CyclicBarrier原始碼分析Java程式設計原始碼
- Java 併發程式設計(十三) -- CountDownLatch原始碼分析Java程式設計CountDownLatch原始碼
- 大白話說java併發工具類-CountDownLatch,CyclicBarrierJavaCountDownLatch
- Java 併發包之CountDownLatch、CyclicBarrierJavaCountDownLatch
- 高併發之ReentrantLock、CountDownLatch、CyclicBarrierReentrantLockCountDownLatch
- 07 併發工具類CountDownLatch、CyclicBarrier、Semaphore使用及原始碼分析CountDownLatch原始碼
- java併發程式設計JUC第九篇:CountDownLatch執行緒同步Java程式設計CountDownLatch執行緒
- java併發程式設計JUC第十篇:CyclicBarrier執行緒同步Java程式設計執行緒
- 併發模擬-程式碼CountDownLatch,SemaphoreCountDownLatch
- 併發程式設計(二)——併發類容器ConcurrentMap程式設計
- 併發程式設計八股程式設計
- 八. Go併發程式設計--errGroupGo程式設計
- java併發程式設計系列:java併發程式設計背景知識Java程式設計
- 聊聊併發(三)——同步輔助類
- JUC 常用4大併發工具類
- Java併發程式設計之CyclicBarrier使用指南Java程式設計
- JUC併發程式設計學習(五)集合類不安全程式設計
- java併發程式設計工具類JUC第二篇:ArrayBlockingQueueJava程式設計BloC
- 併發-6-wait、notify、Semaphore、CountDownLatch、CyclicBarrierAICountDownLatch
- JUC併發程式設計詳解(通俗易懂)程式設計
- JUC併發程式設計基石AQS原始碼之結構篇程式設計AQS原始碼
- 《java併發程式設計的藝術》併發工具類Java程式設計
- Python併發程式設計系列之多程式(multiprocessing)Python程式設計
- java多執行緒10:併發工具類CountDownLatch、CyclicBarrier和SemaphoreJava執行緒CountDownLatch
- 併發程式設計ConcurrentLinkedQueue使用示例詳解程式設計
- Java併發程式設計序列之JUC底層AQSJava程式設計AQS
- 【高併發】AQS中的CountDownLatch、Semaphore與CyclicBarrier用法總結AQSCountDownLatch
- 併發程式設計--常用方法以及CompletableFuture程式設計
- 併發程式設計程式設計