java 線程之concurrent中的常用工具 CyclicBarrier

来源:http://www.cnblogs.com/jalja/archive/2017/07/28/7247411.html
-Advertisement-
Play Games

CyclicBarrier類似於CountDownLatch也是個計數器, 不同的是CyclicBarrier數的是調用了CyclicBarrier.await()進入等待的線程數, 當線程數達到了CyclicBarrier初始時規定的數目時,所有進入等待狀態的線程被喚醒並繼續。 CyclicBar... ...


一、CyclicBarrier 

  CyclicBarrier是一個同步輔助類,它允許一組線程互相等待,直到到達某個公共屏障點 (common barrier point)。在涉及一組固定大小的線程的程式中,這些線程必須不時地互相等待,此時 CyclicBarrier 很有用。因為該 barrier 在釋放等待線程後可以重用,所以稱它為迴圈 的 barrier。
  CyclicBarrier類似於CountDownLatch也是個計數器, 不同的是CyclicBarrier數的是調用了CyclicBarrier.await()進入等待的線程數, 當線程數達到了CyclicBarrier初始時規定的數目時,所有進入等待狀態的線程被喚醒並繼續。 CyclicBarrier就象它名字的意思一樣,可看成是個障礙, 所有的線程必須到齊後才能一起通過這個障礙。 CyclicBarrier初始時還可帶一個Runnable的參數,此Runnable任務在CyclicBarrier的數目達到後,所有其它線程被喚醒前被執行。

A、構造函數       創建一個新的 CyclicBarrier,它將在給定數量的參與者(線程)處於等待狀態時啟動,但它不會在每個 barrier 上執行預定義的操作。

  public CyclicBarrier(int parties) { this(parties, null);}

demo:

 1 package com.jalja.org.thread;
 2 import java.util.concurrent.CyclicBarrier;
 3 import java.util.concurrent.ExecutorService;
 4 import java.util.concurrent.Executors;
 5 public class LockTest {
 6     public static void main(String [] args){
 7         CyclicBarrier cyclicBarrier = new CyclicBarrier(3);
 8         ExecutorService executorService= Executors.newFixedThreadPool(3);
 9         Runnable threadTest=null;
10         for(int i=0;i<3;i++){
11             threadTest=new ThreadTest(cyclicBarrier);
12             executorService.execute(threadTest);
13         }
14         executorService.shutdown();
15     }
16 }
17 class ThreadTest implements Runnable{
18     private CyclicBarrier cyclicBarrier;
19     public ThreadTest(CyclicBarrier cyclicBarrier){
20         this.cyclicBarrier=cyclicBarrier;
21     }
22     public void run() {
23         try {
24             Thread.sleep((long)(Math.random()*10000));
25             System.out.println(Thread.currentThread().getName()+"開始執行");
26             cyclicBarrier.await();
27         }catch (Exception e){
28             e.printStackTrace();
29         }
30         System.out.println(Thread.currentThread().getName()+"執行結束");
31     }
32 }
View Code

B、構造函數      創建一個新的 CyclicBarrier,它將在給定數量的參與者(線程)處於等待狀態時啟動,併在啟動 barrier時執行給定的屏障操作,該操作由最後一個進入 barrier 的線程執行

public CyclicBarrier(int parties, Runnable barrierAction) {
        if (parties <= 0) throw new IllegalArgumentException();
        this.parties = parties;
        this.count = parties;
        this.barrierCommand = barrierAction;
    }

demo: 如果在構造CyclicBarrier對象的時候傳了一個Runnable對象進去,則每次到達公共屏障點的時候都最先執行這個傳進去的Runnable,然後再執行處於等待的Runnable。如果把上面的例子改成下麵這樣:

 1 package com.jalja.org.thread;
 2 import java.util.concurrent.CyclicBarrier;
 3 import java.util.concurrent.ExecutorService;
 4 import java.util.concurrent.Executors;
 5 public class LockTest {
 6     public static void main(String [] args){
 7         CyclicBarrier cyclicBarrier = new CyclicBarrier(3, new Runnable() {
 8             public void run() {
 9                 System.out.println(Thread.currentThread().getName()+"======");
10                 try {
11                     Thread.sleep((long)(Math.random()*10000));
12                 }catch (Exception e){
13                     e.printStackTrace();
14                 }
15                 System.out.println(Thread.currentThread().getName()+"======>");
16             }
17         });
18         ExecutorService executorService= Executors.newFixedThreadPool(3);
19         Runnable threadTest=null;
20         for(int i=0;i<3;i++){
21             threadTest=new ThreadTest(cyclicBarrier);
22             executorService.execute(threadTest);
23         }
24         executorService.shutdown();
25     }
26 }
27 class ThreadTest implements Runnable{
28     private CyclicBarrier cyclicBarrier;
29     public ThreadTest(CyclicBarrier cyclicBarrier){
30         this.cyclicBarrier=cyclicBarrier;
31     }
32     public void run() {
33         try {
34             Thread.sleep((long)(Math.random()*10000));
35             System.out.println(Thread.currentThread().getName()+"開始執行");
36             cyclicBarrier.await();
37         }catch (Exception e){
38             e.printStackTrace();
39         }
40         System.out.println(Thread.currentThread().getName()+"執行結束");
41     }
42 }
View Code

結果:

pool-1-thread-2開始執行
pool-1-thread-3開始執行
pool-1-thread-1開始執行
pool-1-thread-1======
pool-1-thread-1======>
pool-1-thread-1執行結束
pool-1-thread-2執行結束
pool-1-thread-3執行結束

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Java(234,587) 前端(104,327) PHP(90,265) .Net(57,576) .Net的市場需求為何相對Java和PHP這麼低!!! ...
  • 首先我介紹一下為什麼我需要用到ajax技術 1.頁面上有個text類型的輸入框,當我點擊提交的時候,可以把文本框中的值傳遞到後臺去 2.後臺接收傳遞的參數 3.連接資料庫,把傳遞來的內容添加到資料庫里 4.再調用方法把返回值又傳遞到前臺,前臺直接展示我們輸入的內容 前臺 html代碼 @model ...
  • EF Core一次準備多個語句,然後在單次請求中執行它們,所以能提供了更好的性能和速度。本文將介紹它是如何工作的。 ...
  • Visual Studio Ultimate 2013 KEY(密鑰):BWG7X-J98B3-W34RT-33B3R-JVYW9Visual Studio Premium 2013 KEY(密鑰):FBJVC-3CMTX-D8DVP-RTQCT-92494Visual Studio Profess ...
  • WPF中的轉換器是一個非常好的數據類型轉換解決方案,實用和強大, 它的作用是將源數據轉換為WPF自身需要的類型,對數據實體沒有侵略性,會在項目工程中頻繁使用。所以掌握轉換器是WPF開發的必備技能。 我剛接觸轉換器的時候,沒有考慮通用性,每次遇到一個轉換需求都會去創建一個新的轉換器,久而久之,項目中的 ...
  • 可能很多Java的初學者對String的存儲和賦值有迷惑,以下是一個很簡單的測試用例,你只需要花幾分鐘時間便可理解。 1.在看例子之前,確保你理解以下幾個術語: 棧:由JVM分配區域,用於保存線程執行的動作和數據引用。棧是一個運行的單位,Java中一個線程就會相應有一個線程棧與之對應。 堆:由JVM ...
  • 解決python2.7中re模塊的search使用utf8的str出問題,然後做個總結。 ...
  • * 在頁面中使用el表達式如${param.username},相當於在後臺程式(如Servlet)中調用request.getParameter("username"); * 編程中,在頁面中使用el表達式,如 ${param.username} 也可以取到ValueStack中Property ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...