热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java并发工具类之CyclicBarrier

一.介绍CyclicBarrier的字面意思是可以循环使用的(Cyclic)的屏障(Barrier),它主要

一.介绍

CyclicBarrier的字面意思是可以循环使用的(Cyclic)的屏障(Barrier),它主要做的事情是,让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续运行。

图01  :01与02 线程先到达了Barries,被阻塞,等待03线程的到来。

图02 :03 线程到达,Barries开门,02线程获得cpu执行权,先执行。

二. 使用

2.1 CyclicBarrier(int parties)使用

CyclicBarrier(int parties) 构造一个参数,参数代表屏障拦截线程数量。每个线程使用await方法来告诉CyclicBarries线程已经到达屏障,然后对该线程进行阻塞。

public class CyclicBarriesTest {public static CyclicBarrier barrier=new CyclicBarrier(2);public static void main(String[] args) {new Thread(()->{try {int await = barrier.await();} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName());},"t1").start();try {barrier.await();} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName());}
}

简单使用一下,创建CyclicBarries对象,然后线程数量设置成2. 在main方法中创建一个线程,在main函数与新建线程中分别调用await方法。如果你把main方法调用await方法之前让线程睡2s,你可以发现,线程t1与主线程的打印都延长

2.2  CyclicBarrier(int parties, Runnable barrierAction)

双参数构造,第一个参数是阻塞线程数量,第二个参数是所有线程到达屏障的时候,准备释放所有线程之前执行的一个动作(优先执行)。


public class CyclicBarriesTest02 {public static CyclicBarrier barrier =new CyclicBarrier(2, new Runnable() {@Overridepublic void run() {System.out.println("actionRun");}});public static void main(String[] args) {new Thread(()->{try {barrier.await();} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName());},"t1").start();try {barrier.await();} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName());}
}

执行结果:

actionRun
t1
main

三.使用场景

CyclicBarrier可以应用在多线程计算数据,最后合并计算结果的场景。比如我有个Excle保存了我一年的消费流水,然后一个月份一个sheet页,我想计算下我前三个月共消费多少。我就可以使用三个线程算出每个月的消费,最后在汇总。


public class CyclicBarrierTest3 {public static CyclicBarrier barrier &#61;new CyclicBarrier(3, new Runnable() {&#64;Overridepublic void run() {// 汇总Long count&#61; 0L;for (Map.Entry e :map.entrySet()) {count&#61;count&#43;e.getValue();}System.out.println("汇总&#xff1a;"&#43;count);}});public static ConcurrentMap map &#61;new ConcurrentHashMap<>();public static Executor executor &#61; Executors.newFixedThreadPool(3);// 使用3个线程算三个月的sheetpublic static void main(String[] args) {for (int i &#61; 0;i<3;&#43;&#43;i){executor.execute(()->{map.put(Thread.currentThread().getName(),System.currentTimeMillis());try {barrier.await();} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}});}}}

使用三个线程计算出3个sheet页里的数据&#xff0c;最后使用CyclicBarrier 构造参数action 来汇总数据。输出结果如下&#xff1a;

汇总&#xff1a;4695037414899

注&#xff1a;本文章参考《java并发编程的艺术》&#xff0c;感谢方老师作品。


推荐阅读
  • 并发编程 12—— 任务取消与关闭 之 shutdownNow 的局限性
    Java并发编程实践目录并发编程01——ThreadLocal并发编程02——ConcurrentHashMap并发编程03——阻塞队列和生产者-消费者模式并发编程04——闭锁Co ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 深入解析Java多线程与并发库的应用:空中网实习生面试题详解
    本文详细探讨了Java多线程与并发库的高级应用,结合空中网在挑选实习生时的面试题目,深入分析了相关技术要点和实现细节。文章通过具体的代码示例展示了如何使用Semaphore和SynchronousQueue来管理线程同步和任务调度。 ... [详细]
  • 深入理解Java多线程并发处理:基础与实践
    本文探讨了Java中的多线程并发处理机制,从基本概念到实际应用,帮助读者全面理解并掌握多线程编程技巧。通过实例解析和理论阐述,确保初学者也能轻松入门。 ... [详细]
  • 深入剖析JVM垃圾回收机制
    本文详细探讨了Java虚拟机(JVM)中的垃圾回收机制,包括其意义、对象判定方法、引用类型、常见垃圾收集算法以及各种垃圾收集器的特点和工作原理。通过理解这些内容,开发人员可以更好地优化内存管理和程序性能。 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 本文详细介绍了Grand Central Dispatch (GCD) 的核心概念和使用方法,探讨了任务队列、同步与异步执行以及常见的死锁问题。通过具体示例和代码片段,帮助开发者更好地理解和应用GCD进行多线程开发。 ... [详细]
  • Java多线程实现:从1到100分段求和并汇总结果
    本文介绍如何使用Java编写一个程序,通过10个线程分别计算不同区间的和,并最终汇总所有线程的结果。每个线程负责计算一段连续的整数之和,最后将所有线程的结果相加。 ... [详细]
  • 本文详细介绍了Java中实现异步调用的多种方式,包括线程创建、Future接口、CompletableFuture类以及Spring框架的@Async注解。通过代码示例和深入解析,帮助读者理解并掌握这些技术。 ... [详细]
  • 本文探讨了如何通过一系列技术手段提升Spring Boot项目的并发处理能力,解决生产环境中因慢请求导致的系统性能下降问题。 ... [详细]
  • 异常要理解Java异常处理是如何工作的,需要掌握一下三种异常类型:检查性异常:最具代表性的检查性异常是用户错误或问题引起的异常ÿ ... [详细]
  • 本文详细解析了Java中hashCode()和equals()方法的实现原理及其在哈希表结构中的应用,探讨了两者之间的关系及其实现时需要注意的问题。 ... [详细]
  • 雨林木风 GHOST XP SP3 经典珍藏版 V2017.11
    雨林木风 GHOST XP SP3 经典珍藏版 V2017.11 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 本文深入探讨了SQL数据库中常见的面试问题,包括如何获取自增字段的当前值、防止SQL注入的方法、游标的作用与使用、索引的形式及其优缺点,以及事务和存储过程的概念。通过详细的解答和示例,帮助读者更好地理解和应对这些技术问题。 ... [详细]
author-avatar
梦幻死灵_791
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有