多線程(八、同步計數(shù)器-CyclicBarrier)

CyclicBarrier-循環(huán)柵欄

線程到達(dá)柵欄時調(diào)用await方法被阻塞,只有線程數(shù)據(jù)達(dá)到柵欄設(shè)置的閾值時,柵欄放行,所有線程繼續(xù)執(zhí)行,此輪結(jié)束,柵欄進入下一輪。

案例:3個線程等待柵欄放行

Task

import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;

public class Task implements Runnable{

    private CyclicBarrier cyclicBarrier;

    public Task(CyclicBarrier cyclicBarrier) {
        this.cyclicBarrier = cyclicBarrier;
    }

    @Override
    public void run() {
        try {
            Thread.sleep(1000);
            System.out.println(Thread.currentThread().getName() + "準(zhǔn)備就緒");
            cyclicBarrier.await();
        } catch (InterruptedException e) {
            System.out.println(Thread.currentThread().getName() + "中斷了......");
        } catch (BrokenBarrierException e) {
            System.out.println(Thread.currentThread().getName() + "拋出損壞異常....");
        }
    }
}

啟動文件

import java.util.concurrent.CyclicBarrier;

public class Main {

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

        System.out.println("主線程開始......");

        CyclicBarrier cb = new CyclicBarrier(3, new Runnable(){

            @Override
            public void run() {
                System.out.println("子線程全部就位,開始執(zhí)行制定任務(wù)......");
            }
        });

        Thread t1 = new Thread(new Task(cb), "Thread-1");
        Thread t2 = new Thread(new Task(cb), "Thread-2");
        Thread t3 = new Thread(new Task(cb), "Thread-3");

        t1.start();
        t2.start();
        t3.start();

        Thread.sleep(2000);
        System.out.println("主線程執(zhí)行完畢");
    }
}

結(jié)果:

多線程(八、同步計數(shù)器-CyclicBarrier)

成都創(chuàng)新互聯(lián)主營玉溪網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,重慶APP開發(fā)公司,玉溪h5微信平臺小程序開發(fā)搭建,玉溪網(wǎng)站營銷推廣歡迎玉溪等地區(qū)企業(yè)咨詢

CyclicBarrier的異常

CyclicBarrier如果不能滿足閾值,超時或者等待的線程被中斷了,則所有等待線程都會拋出損壞異常,然后進入下一輪。

多線程(八、同步計數(shù)器-CyclicBarrier)

案例:損壞異常,假設(shè)閾值為4,已經(jīng)有3個線程等待,其中一個中斷。

Task代碼不變

啟動文件修改

import java.util.concurrent.CyclicBarrier;

public class Main {

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

        System.out.println("主線程開始......");

        CyclicBarrier cb = new CyclicBarrier(4, new Runnable(){

            @Override
            public void run() {
                System.out.println("子線程全部就位,開始執(zhí)行制定任務(wù)......");
            }
        });

        Thread t1 = new Thread(new Task(cb), "Thread-1");
        Thread t2 = new Thread(new Task(cb), "Thread-2");
        Thread t3 = new Thread(new Task(cb), "Thread-3");

        t1.start();
        t2.start();
        t3.start();
        Thread.sleep(1000);
        t1.interrupt();

        Thread.sleep(2000);
        System.out.println("主線程執(zhí)行完畢");
    }
}

結(jié)果:

多線程(八、同步計數(shù)器-CyclicBarrier)

源碼分析:

CyclicBarrier基于ReentrantLock和Condition實現(xiàn)鎖機制。

多線程(八、同步計數(shù)器-CyclicBarrier)

成員變量

多線程(八、同步計數(shù)器-CyclicBarrier)

await方法:

多線程(八、同步計數(shù)器-CyclicBarrier)
多線程(八、同步計數(shù)器-CyclicBarrier)
多線程(八、同步計數(shù)器-CyclicBarrier)

breakBarrier損壞方法:

多線程(八、同步計數(shù)器-CyclicBarrier)

網(wǎng)頁題目:多線程(八、同步計數(shù)器-CyclicBarrier)
分享路徑:http://muchs.cn/article28/ghhgcp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計App設(shè)計、商城網(wǎng)站、網(wǎng)站設(shè)計、域名注冊網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站