J.U.C之AQS-CyclicBarrier

CyclicBarrier 也是 AQS 的同步組件

CyclicBarrier

AQS 的同步組件之 CyclicBarrier

CyclicBarrier也是一個同步輔助類 , 它允許一組線程相互等待 , 直到到達某個公共的屏障點 , 通過它可以完成多個線程之間相互等待 ,只有當每個線程都準備好之后, 才能各自繼續(xù)往下執(zhí)行后續(xù)的操作, 和 CountDownLatch相似的地方就是, 它也是通過計數器來實現的. 當某個線程調用了 await()方法之后, 該線程就進入了等待狀態(tài) . 而且計數器就進行 +1 操作 , 當計數器的值達到了我們設置的初始值的時候 , 之前調用了await() 方法而進入等待狀態(tài)的線程會被喚醒繼續(xù)執(zhí)行后續(xù)的操作. 因為 CyclicBarrier釋放線程之后可以重用, 所以又稱之為循環(huán)屏障 . CyclicBarrier 使用場景和 CountDownLatch 很相似 , 可以用于多線程計算數據, 最后合并計算結果的應用場景 .

CyclicBarrier 與 CountDownLatch 區(qū)別

  • CountDownLatch的計數器只能使用一次 , 而 CyclicBarrier 的計數器可以使用 reset重置 循環(huán)使用

  • CountDownLatch 主要事項 1 個 或者 n 個線程需要等待其它線程完成某項操作之后才能繼續(xù)往下執(zhí)行 , 其描述的是 1 個 或者 n 個線程與其它線程的關系 ; CyclicBarrier 主要是實現了 1 個或者多個線程之間相互等待,直到所有的線程都滿足條件之后, 才執(zhí)行后續(xù)的操作 , 其描述的是內部各個線程相互等待的關系 .

    CyclicBarrier 假如有 5 個線程都調用了 await() 方法 , 那這個 5 個線程就等著 , 當這 5 個線程都準備好之后, 它們有各自往下繼續(xù)執(zhí)行 , 如果這 5 個線程在后續(xù)有一個計算發(fā)生錯誤了 , 這里可以重置計數器 , 并讓這 5 個線程再執(zhí)行一遍 .

CyclicBarrier 代碼演示

  • 演示代碼1

import lombok.extern.slf4j.Slf4j;

import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * Created by Charles 
 */
@Slf4j
public class CyclicBarrierExample1 {
    private static CyclicBarrier barrier = new CyclicBarrier(5); // 5 個線程同步等待

    public static void main(String[] args) throws Exception {

        ExecutorService executor = Executors.newCachedThreadPool();

        for (int i = 0; i < 10; i++) {
            final int threadNum = i;
            Thread.sleep(1000);
            executor.execute(() -> {
                try {
                    race(threadNum);
                } catch (Exception e) {
                    log.error("exception", e);
                }
            });
        }
        executor.shutdown();
    }

    private static void race(int threadNum) throws Exception {
        Thread.sleep(1000);
        log.info("{} is ready", threadNum);
        barrier.await(); // 有一個線程準備 ok 了 , 當達到上面設置的5個線程 的時候 , 后續(xù)代碼就開始執(zhí)行了
        log.info("{} continue", threadNum);
    }
}

控制臺輸出


測試代碼控制臺輸出結果
  • 演示代碼 2 (帶有等待時間)

import lombok.extern.slf4j.Slf4j;

import java.util.concurrent.*;

/**
 * Created by Charles 
 */
@Slf4j
public class CyclicBarrierExample2 {
    private static CyclicBarrier barrier = new CyclicBarrier(5);

    public static void main(String[] args) throws Exception {

        ExecutorService executor = Executors.newCachedThreadPool();

        for (int i = 0; i < 10; i++) {
            final int threadNum = i;
            Thread.sleep(1000);
            executor.execute(() -> {
                try {
                    race(threadNum);
                } catch (Exception e) {
                    log.error("exception", e);
                }
            });
        }
        executor.shutdown();
    }

    private static void race(int threadNum) throws Exception {
        Thread.sleep(1000);
        log.info("{} is ready", threadNum);
        try {
            barrier.await(2000, TimeUnit.MILLISECONDS); //等待2000 毫秒后繼續(xù)執(zhí)行
        } catch (BrokenBarrierException | TimeoutException e) {
            log.warn("BarrierException",e);
        }
        log.info("{} continue", threadNum);
    }
}

控制臺輸出結果如下圖 :


測試代碼控制臺輸出結果
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末恰起,一起剝皮案震驚了整個濱河市饥追,隨后出現的幾起案子哟楷,更是在濱河造成了極大的恐慌呼巷,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異纪吮,居然都是意外死亡俩檬,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進店門碾盟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來棚辽,“玉大人,你說我怎么就攤上這事冰肴∏辏” “怎么了?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵熙尉,是天一觀的道長联逻。 經常有香客問我,道長检痰,這世上最難降的妖魔是什么包归? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮铅歼,結果婚禮上公壤,老公的妹妹穿的比我還像新娘。我一直安慰自己椎椰,他們只是感情好厦幅,可當我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著俭识,像睡著了一般慨削。 火紅的嫁衣襯著肌膚如雪洞渔。 梳的紋絲不亂的頭發(fā)上套媚,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機與錄音磁椒,去河邊找鬼堤瘤。 笑死,一個胖子當著我的面吹牛浆熔,可吹牛的內容都是我干的本辐。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼医增,長吁一口氣:“原來是場噩夢啊……” “哼慎皱!你這毒婦竟也來了?” 一聲冷哼從身側響起叶骨,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤茫多,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后忽刽,有當地人在樹林里發(fā)現了一具尸體天揖,經...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡夺欲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現自己被綠了今膊。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片些阅。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖斑唬,靈堂內的尸體忽然破棺而出市埋,到底是詐尸還是另有隱情,我是刑警寧澤赖钞,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布腰素,位于F島的核電站,受9級特大地震影響雪营,放射性物質發(fā)生泄漏弓千。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一献起、第九天 我趴在偏房一處隱蔽的房頂上張望洋访。 院中可真熱鬧,春花似錦谴餐、人聲如沸姻政。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽汁展。三九已至,卻和暖如春厌殉,著一層夾襖步出監(jiān)牢的瞬間食绿,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工公罕, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留器紧,地道東北人。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓楼眷,卻偏偏與公主長得像铲汪,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子罐柳,可洞房花燭夜當晚...
    茶點故事閱讀 45,044評論 2 355