CountdownLacth CyclicBarrier Join

CountdownLacth CyclicBarrier Join

Join:main里面調(diào)用t1.join,阻塞main線程,直到t1線程結(jié)束,main線程繼續(xù)執(zhí)行.
countdownLacth:線程計數(shù)器,初始化時指定計數(shù)器數(shù)值,阻塞await線程,直到計數(shù)器為0,被阻塞的線程執(zhí)行,調(diào)用countDown()不會阻塞當前線程.
CyclicBarrier:多個線程同時阻塞在await處,當所有線程都執(zhí)行到await處時,所有await的線程同時往下執(zhí)行.

Join示例代碼

public class JoinTest {
    public static void main(String[] args) {

        System.out.println("進入主線程");

        Thread t1 = new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    System.out.println("t1線程開始執(zhí)行");
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println("t1線程執(zhí)行完畢");
            }
        });
        t1.start();
        try {
            System.out.println("主線程開始等待");
            t1.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("主線程繼續(xù)執(zhí)行");
    }
}

log信息
進入主線程
主線程開始等待
t1線程開始執(zhí)行
t1線程執(zhí)行完畢
主線程繼續(xù)執(zhí)行

countdownLacth示例

public class UseCountDownLatch {

    public static void main(String[] args) {
        //初始化countdownLatch時設置計數(shù)器數(shù)字,如果這個案例改成3,那么t1永遠在await
        final CountDownLatch countDown = new CountDownLatch(2);
        
        Thread t1 = new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    System.out.println("進入線程t1" + "等待其他線程處理完成...");
                    countDown.await();
                    System.out.println("t1線程繼續(xù)執(zhí)行...");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        },"t1");
        
        Thread t2 = new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    System.out.println("t2線程初始化完畢颠区,2s后計數(shù)器減一...");
                    Thread.sleep(2000);
                    countDown.countDown();
                    System.out.println("t2繼續(xù)執(zhí)行,");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        });
        Thread t3 = new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    System.out.println("t3線程進行初始化操作,4s后計數(shù)器減一");
                    Thread.sleep(4000);
                    System.out.println("t3線程初始化完畢通铲,計數(shù)器減一...");
                    countDown.countDown();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        });
        
        t1.start();
        t2.start();
        t3.start();
    }
}

log信息
t2線程初始化完畢毕莱,2s后計數(shù)器減一...
t3線程進行初始化操作,4s后計數(shù)器減一
進入線程t1等待其他線程處理完成...
t2繼續(xù)執(zhí)行,
t3線程初始化完畢测暗,計數(shù)器減一...
t1線程繼續(xù)執(zhí)行...


CyclicBarrier代碼示例

public class CyclicBarrierTest {

    static final CyclicBarrier barrier=new CyclicBarrier(3);


    static class test implements Runnable{

        @Override
        public void run() {
            try {
                System.out.println("進入線程"+Thread.currentThread().getId()+"開始執(zhí)行任務");
                Thread.sleep(3000);
                System.out.println("線程"+Thread.currentThread().getId()+"進入等待");
                barrier.await();
            } catch (InterruptedException e) {
                e.printStackTrace();
            } catch (BrokenBarrierException e) {
                e.printStackTrace();
            }
            System.out.println("線程"+Thread.currentThread().getId()+"開始執(zhí)行");
        }
    }

    public static void main(String[] args) {

        ExecutorService executor= Executors.newFixedThreadPool(3);
        executor.submit(new test());
        executor.submit(new test());
        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        executor.submit(new test());
    }
}

log信息
進入線程12開始執(zhí)行任務
進入線程11開始執(zhí)行任務
線程11進入等待
線程12進入等待
進入線程13開始執(zhí)行任務
線程13進入等待
線程13開始執(zhí)行
線程11開始執(zhí)行
線程12開始執(zhí)行

寫這個示例的時候犯蠢了,線程池初始的時候?qū)懥?“newFixedThreadPool(2)”, CyclicBarrier(3)計數(shù)器是3央串,開始執(zhí)行時卡住了 log信息如下
進入線程11開始執(zhí)行任務
進入線程12開始執(zhí)行任務
線程11進入等待
線程12進入等待
然后就不動了,仔細一想,線程池一共2條線程,全被await阻塞著,導致沒有線程執(zhí)行第三個任務了,形成了我等t3,t3等t1碗啄,t2線程釋放,死循壞.

這3個都有阻塞線程的功能,但是有所區(qū)別

join:阻塞當前線程,只有等子線程完全執(zhí)行完成之后才能繼續(xù)執(zhí)行,不是那么靈活.
CyclicBarrier:在多個線程中設置阻塞點,直到所有所有線程都執(zhí)行到阻塞點,所有被阻塞的線程才同時進行執(zhí)行质和。
countdownLacth:阻塞一個或多個線程,等待任務線程執(zhí)行,任務線程到一定程度就可以調(diào)用countdown稚字,然后不會阻塞任務線程,當計數(shù)器為0時主線程恢復執(zhí)行.比join更加靈活一些饲宿,也可以實現(xiàn)CyclicBarrier的效果,就是麻煩一些。如果計數(shù)器為先設置為0,在進行await,那么對線程沒有阻塞作用.
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末胆描,一起剝皮案震驚了整個濱河市瘫想,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌昌讲,老刑警劉巖国夜,帶你破解...
    沈念sama閱讀 212,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異短绸,居然都是意外死亡车吹,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評論 3 385
  • 文/潘曉璐 我一進店門醋闭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來窄驹,“玉大人,你說我怎么就攤上這事证逻±植海” “怎么了?”我有些...
    開封第一講書人閱讀 158,369評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長丈咐。 經(jīng)常有香客問我瑞眼,道長,這世上最難降的妖魔是什么扯罐? 我笑而不...
    開封第一講書人閱讀 56,799評論 1 285
  • 正文 為了忘掉前任负拟,我火速辦了婚禮,結(jié)果婚禮上歹河,老公的妹妹穿的比我還像新娘掩浙。我一直安慰自己,他們只是感情好秸歧,可當我...
    茶點故事閱讀 65,910評論 6 386
  • 文/花漫 我一把揭開白布厨姚。 她就那樣靜靜地躺著,像睡著了一般键菱。 火紅的嫁衣襯著肌膚如雪谬墙。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,096評論 1 291
  • 那天经备,我揣著相機與錄音拭抬,去河邊找鬼。 笑死侵蒙,一個胖子當著我的面吹牛造虎,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播纷闺,決...
    沈念sama閱讀 39,159評論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼算凿,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了犁功?” 一聲冷哼從身側(cè)響起氓轰,我...
    開封第一講書人閱讀 37,917評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎浸卦,沒想到半個月后署鸡,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,360評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡限嫌,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,673評論 2 327
  • 正文 我和宋清朗相戀三年靴庆,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片萤皂。...
    茶點故事閱讀 38,814評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡撒穷,死狀恐怖匣椰,靈堂內(nèi)的尸體忽然破棺而出裆熙,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 34,509評論 4 334
  • 正文 年R本政府宣布入录,位于F島的核電站蛤奥,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏僚稿。R本人自食惡果不足惜凡桥,卻給世界環(huán)境...
    茶點故事閱讀 40,156評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蚀同。 院中可真熱鬧缅刽,春花似錦、人聲如沸蠢络。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽刹孔。三九已至啡省,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間髓霞,已是汗流浹背卦睹。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留方库,地道東北人结序。 一個月前我還...
    沈念sama閱讀 46,641評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像薪捍,于是被迫代替她去往敵國和親笼痹。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,728評論 2 351

推薦閱讀更多精彩內(nèi)容