并发编程系列---【CyclicBarrier】

发布时间:2022-06-28 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了并发编程系列---【CyclicBarrier】脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

作用:执行第一个参数指定的次数之后,最后一个线程执行第二个参数中的任务。

应用场景:在微服务中调用五个接口,确保5个接口执行完毕,再执行自己的业务逻辑。

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

public class CyclicBarrierDemo {

    static class Task implements Runnable {
        
        CyclicBarrier barrier;
        
        public Task(CyclicBarrier barrier) {
            this.barrier = barrier;
        }
        
        @Override
        public void run() {
            try {
                Thread.sleep(new Random().nextInt(10) * 1000);
                System.out.println(Thread.currentThread().getName() + " 检查火箭");
                barrier.await();//标记子任务执行完了,让count++  => 满足count => 调用CyclicBarrier的参数2任务

            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
    
    public static void main(String[] args) {
        int count = 10;
        ExecutorService exec = Executors.newFixedThreadPool(count);


        CyclicBarrier barrier = new CyclicBarrier(5, new Runnable() {
            
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName() + " -------------------发射火箭");
            }
        });
        
        for(int i = 0; i < count; i++) {
            exec.execute(new Task(barrier));
        }
        exec.shutdown();
    }
    
}

 

脚本宝典总结

以上是脚本宝典为你收集整理的并发编程系列---【CyclicBarrier】全部内容,希望文章能够帮你解决并发编程系列---【CyclicBarrier】所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: