文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java中CyclicBarrier循环屏障怎么应用

2023-06-30 15:53

关注

这篇“Java中CyclicBarrier循环屏障怎么应用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java中CyclicBarrier循环屏障怎么应用”文章吧。

一、简介

CyclicBarrier 字面意思回环栅栏(循环屏障),它可以实现让一组线程等待至某个状态(屏障点)之后再全部同时执行。叫做回环是因为当所有等待线程都被释放以后,CyclicBarrier可以被重用。 

Java中CyclicBarrier循环屏障怎么应用

CyclicBarrier 作用是让一组线程相互等待,当达到一个共同点时,所有之前等待的线程再继续执行,且 CyclicBarrier 功能可重复使用。

二、CyclicBarrier的使用

构造方法:

 // parties表示屏障拦截的线程数量,每个线程调用 await 方法告诉 CyclicBarrier 我已经到达了屏障,然后当前线程被阻塞。 public CyclicBarrier(int parties) // 用于在线程到达屏障时,优先执行 barrierAction,方便处理更复杂的业务场景(该线程的执行时机是在到达屏障之后再执行)

重要方法:

//屏障 指定数量的线程全部调用await()方法时,这些线程不再阻塞// BrokenBarrierException 表示栅栏已经被破坏,破坏的原因可能是其中一个线程 await() 时被中断或者超时public int await() throws InterruptedException, BrokenBarrierExceptionpublic int await(long timeout, TimeUnit unit) throws InterruptedException, BrokenBarrierException, TimeoutException//循环  通过reset()方法可以进行重置

CyclicBarrier 应用场景

模拟合并计算场景

利用 CyclicBarrier 可以用于多线程计算数据,最后合并计算结果的场景。

public class CyclicBarrierTest2 {    //保存每个学生的平均成绩    private Conc urrentHashMap<String, Integer> map=new ConcurrentHashMap<String,Integer>();    private ExecutorService threadPool= Executors.newFixedThreadPool(3);    private CyclicBarrier cb=new CyclicBarrier(3,()->{        int result=0;        Set<String> set = map.keySet();        for(String s:set){            result+=map.get(s);        }        System.out.println("三人平均成绩为:"+(result/3)+"分");    });    public void count(){        for(int i=0;i<3;i++){            threadPool.execute(new Runnable(){                @Override                public void run() {                    //获取学生平均成绩                    int score=(int)(Math.random()*40+60);                    map.put(Thread.currentThread().getName(), score);                    System.out.println(Thread.currentThread().getName()                            +"同学的平均成绩为:"+score);                    try {                        //执行完运行await(),等待所有学生平均成绩都计算完毕                        cb.await();                    } catch (InterruptedException | BrokenBarrierException e) {                        e.printStackTrace();                    }                }            });        }    }    public static void main(String[] args) {        CyclicBarrierTest2 cb=new CyclicBarrierTest2();        cb.count();    }}

模拟“人满发车”的场景

利用CyclicBarrier的计数器能够重置,屏障可以重复使用的特性,可以支持类似“人满发车”的场景

public class CyclicBarrierTest3 {    public static void main(String[] args) {        AtomicInteger counter = new AtomicInteger();        ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(                5, 5, 1000, TimeUnit.SECONDS,                new ArrayBlockingQueue<>(100),                (r) -> new Thread(r, counter.addAndGet(1) + " 号 "),                new ThreadPoolExecutor.AbortPolicy());        CyclicBarrier cyclicBarrier = new CyclicBarrier(5,                () -> System.out.println("裁判:比赛开始~~"));        for (int i = 0; i < 10; i++) {            threadPoolExecutor.submit(new Runner(cyclicBarrier));        }    }    static class Runner extends Thread{        private CyclicBarrier cyclicBarrier;        public Runner (CyclicBarrier cyclicBarrier) {            this.cyclicBarrier = cyclicBarrier;        }        @Override        public void run() {            try {                int sleepMills = ThreadLocalRandom.current().nextInt(1000);                Thread.sleep(sleepMills);                System.out.println(Thread.currentThread().getName() + " 选手已就位, 准备共用时: " + sleepMills + "ms" + cyclicBarrier.getNumberWaiting());                cyclicBarrier.await();            } catch (InterruptedException e) {                e.printStackTrace();            }catch(BrokenBarrierException e){                e.printStackTrace();            }        }    }}

输出结果:

3 号  选手已就位, 准备共用时: 78ms0
1 号  选手已就位, 准备共用时: 395ms1
5 号  选手已就位, 准备共用时: 733ms2
2 号  选手已就位, 准备共用时: 776ms3
4 号  选手已就位, 准备共用时: 807ms4
裁判:比赛开始~~
4 号  选手已就位, 准备共用时: 131ms0
3 号  选手已就位, 准备共用时: 256ms1
2 号  选手已就位, 准备共用时: 291ms2
1 号  选手已就位, 准备共用时: 588ms3
5 号  选手已就位, 准备共用时: 763ms4
裁判:比赛开始~~

三、CyclicBarrier 源码分析

CyclicBarrier 流程

主要是的流程:

下面是一个简单的流程图:

Java中CyclicBarrier循环屏障怎么应用

下面是具体的一些代码调用的流程:

Java中CyclicBarrier循环屏障怎么应用

几个常见的问题?

CyclicBarrier 与 CountDownLatch的区别

以上就是关于“Java中CyclicBarrier循环屏障怎么应用”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯