Java线程--CyclicBarrier使用
阅读原文时间:2023年07月09日阅读:1

原创:转载需注明原创地址 https://www.cnblogs.com/fanerwei222/p/11867687.html

Java线程--CyclicBarrier使用, 代码里头有详细注释:

public static void main(String[] args) {
/**
* 可循环使用的栅栏
* parties表示需要多少个线程同时执行, 相当于一个起跑线
* 2代表2个线程必须在 await()方法的地方都暂停一下, 等其他人到齐了一起执行
* 第二个参数代表新建一个线程在所有等待的线程方法之前执行
*/
CyclicBarrier cyclicBarrier = new CyclicBarrier(2, new Runnable() {
@Override
public void run() {
System.out.println("先执行这个方法!");
}
});
ExecutorService service1 = Executors.newSingleThreadExecutor();
service1.execute(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(3000);
/**
* 设定一个起跑点 , 所有设置了await()方法的线程都必须等到这个时候开始执行
* 不能抢跑
*/
cyclicBarrier.await();
System.out.println(new Date());
} catch (InterruptedException | BrokenBarrierException e) {
e.printStackTrace();
}
System.out.println("子线程:"+Thread.currentThread().getName()+"执行");
}
});
service1.shutdown();

    ExecutorService service2 = Executors.newSingleThreadExecutor();  
    service2.execute(new Runnable() {  
        @Override  
        public void run() {  
            try {  
                Thread.sleep(3000);  
                /\*\*  
                 \* 设定一个起跑点 , 所有设置了await()方法的线程都必须等到这个时候开始执行  
                 \* 不能抢跑  
                 \*/  
                cyclicBarrier.await();  
                System.out.println(new Date());  
            } catch (InterruptedException | BrokenBarrierException e) {  
                e.printStackTrace();  
            }  
            System.out.println("子线程:"+Thread.currentThread().getName()+"执行");  
        }  
    });  
    service2.shutdown();  
}

打印如下;

先执行这个方法!
Fri Nov 15 16:51:14 CST 2019
Fri Nov 15 16:51:14 CST 2019
子线程:pool-1-thread-1执行
子线程:pool-2-thread-1执行