Java多线程之----CyclicBarrier

2024-08-30 10:08

本文主要是介绍Java多线程之----CyclicBarrier,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    CyclicBarrier可以实现多个线程互相的等待,当每个线程到达某个点的时候,会阻塞直到所有的线程都完成之后,才继续执行

    CyclicBarrier和上次介绍的CountDownLatch有点类似,但是也有不同,主要不同点如下:

  • CyclicBarrier是多个线程互相等待,CountDownLatch是一个线程等待多个线程
  • CyclicBarrier可以重复使用,而CountDownLatch不可以

    用法和CountDownLatch类似,有这样的情景:现在需要多个线程进行一项统计任务,每个线程统计完后,需要等待别的线程完成之后,才会继续执行本线程的汇总任务,看下代码

public class CyclicBarrierTest {public static void main(String[] args) {CyclicBarrier barrier = new CyclicBarrier(5);for (int i = 0; i < 5; i++) {Thread t = new Thread(new Task(barrier));t.start();}}
}class Task implements Runnable {private CyclicBarrier barrier;public Task(CyclicBarrier barrier) {this.barrier = barrier;}@Overridepublic void run() {try {Thread.sleep((int) (Math.random() * 10) * 1000);System.out.println("线程" + Thread.currentThread().getName() + "结束统计任务 ,等待其他线程完成....");barrier.await();// 调用该方法之后,将会停止运行,直到其他线程都完成才继续往下运行Thread.sleep((int) (Math.random() * 10) * 1000);System.out.println("线程" + Thread.currentThread().getName() + "开始进行汇总....");} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}}
}
// 结果如下
// 线程Thread-2结束统计任务 ,等待其他线程完成....
// 线程Thread-1结束统计任务 ,等待其他线程完成....
// 线程Thread-3结束统计任务 ,等待其他线程完成....
// 线程Thread-0结束统计任务 ,等待其他线程完成....
// 线程Thread-4结束统计任务 ,等待其他线程完成....
// 线程Thread-1开始进行汇总....
// 线程Thread-0开始进行汇总....
// 线程Thread-4开始进行汇总....
// 线程Thread-2开始进行汇总....
// 线程Thread-3开始进行汇总....
    调用了CyclicBarrier的await方法之后,该线程会等到其他线程都到达这个点,如果所有线程到达了则继续往下运行,如果没有全部到达,则继续等待

    

    再看另外的例子,加深一下印象:现在有一个会议,会议需要在所有人都到达之后,才会开始,会议开始后,所有人才可以进行发言

    看下代码

public class CyclicBarrierDemo {public static void main(String[] args) {CyclicBarrier barrier = new CyclicBarrier(5, new Conference());for (int i = 0; i < 5; i++) {new Thread(new Paticipant(barrier, "参与者" + i)).start();}}public static class Paticipant implements Runnable {private CyclicBarrier barrier;private String name;public Paticipant(CyclicBarrier barrier, String name) {this.barrier = barrier;this.name = name;}@Overridepublic void run() {try {Thread.sleep((int) (Math.random() * 10) * 1000);System.out.println(name + "到达....");barrier.await();Thread.sleep((int) (Math.random() * 10) * 1000);System.out.println(name + "进行发言");} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}}}public static class Conference implements Runnable {@Overridepublic void run() {System.out.println("所有人到齐,会议开始,参与者发言论");}}
}
// 结果如下
// 参与者2到达....
// 参与者3到达....
// 参与者0到达....
// 参与者4到达....
// 参与者1到达....
// 所有人到齐,会议开始,参与者发言论
// 参与者4进行发言
// 参与者3进行发言
// 参与者1进行发言
// 参与者2进行发言
// 参与者0进行发言
    这里CyclicBarrier的构造方法传入了一个Runnable对象,当所有线程都到达的时候,会执行这个对象的run方法,然后再继续运行每个线程的后面的代码





这篇关于Java多线程之----CyclicBarrier的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1120520

相关文章

Java实战之利用POI生成Excel图表

《Java实战之利用POI生成Excel图表》ApachePOI是Java生态中处理Office文档的核心工具,这篇文章主要为大家详细介绍了如何在Excel中创建折线图,柱状图,饼图等常见图表,需要的... 目录一、环境配置与依赖管理二、数据源准备与工作表构建三、图表生成核心步骤1. 折线图(Line Ch

Spring Boot 3 整合 Spring Cloud Gateway实践过程

《SpringBoot3整合SpringCloudGateway实践过程》本文介绍了如何使用SpringCloudAlibaba2023.0.0.0版本构建一个微服务网关,包括统一路由、限... 目录引子为什么需要微服务网关实践1.统一路由2.限流防刷3.登录鉴权小结引子当前微服务架构已成为中大型系统的标

Java集合中的List超详细讲解

《Java集合中的List超详细讲解》本文详细介绍了Java集合框架中的List接口,包括其在集合中的位置、继承体系、常用操作和代码示例,以及不同实现类(如ArrayList、LinkedList和V... 目录一,List的继承体系二,List的常用操作及代码示例1,创建List实例2,增加元素3,访问元

Python中多线程和多进程的基本用法详解

《Python中多线程和多进程的基本用法详解》这篇文章介绍了Python中多线程和多进程的相关知识,包括并发编程的优势,多线程和多进程的概念、适用场景、示例代码,线程池和进程池的使用,以及如何选择合适... 目录引言一、并发编程的主要优势二、python的多线程(Threading)1. 什么是多线程?2.

Java中将异步调用转为同步的五种实现方法

《Java中将异步调用转为同步的五种实现方法》本文介绍了将异步调用转为同步阻塞模式的五种方法:wait/notify、ReentrantLock+Condition、Future、CountDownL... 目录异步与同步的核心区别方法一:使用wait/notify + synchronized代码示例关键

Java 8 Stream filter流式过滤器详解

《Java8Streamfilter流式过滤器详解》本文介绍了Java8的StreamAPI中的filter方法,展示了如何使用lambda表达式根据条件过滤流式数据,通过实际代码示例,展示了f... 目录引言 一.Java 8 Stream 的过滤器(filter)二.Java 8 的 filter、fi

Java中实现订单超时自动取消功能(最新推荐)

《Java中实现订单超时自动取消功能(最新推荐)》本文介绍了Java中实现订单超时自动取消功能的几种方法,包括定时任务、JDK延迟队列、Redis过期监听、Redisson分布式延迟队列、Rocket... 目录1、定时任务2、JDK延迟队列 DelayQueue(1)定义实现Delayed接口的实体类 (

springboot的调度服务与异步服务使用详解

《springboot的调度服务与异步服务使用详解》本文主要介绍了Java的ScheduledExecutorService接口和SpringBoot中如何使用调度线程池,包括核心参数、创建方式、自定... 目录1.调度服务1.1.JDK之ScheduledExecutorService1.2.spring

将java程序打包成可执行文件的实现方式

《将java程序打包成可执行文件的实现方式》本文介绍了将Java程序打包成可执行文件的三种方法:手动打包(将编译后的代码及JRE运行环境一起打包),使用第三方打包工具(如Launch4j)和JDK自带... 目录1.问题提出2.如何将Java程序打包成可执行文件2.1将编译后的代码及jre运行环境一起打包2

Java使用Tesseract-OCR实战教程

《Java使用Tesseract-OCR实战教程》本文介绍了如何在Java中使用Tesseract-OCR进行文本提取,包括Tesseract-OCR的安装、中文训练库的配置、依赖库的引入以及具体的代... 目录Java使用Tesseract-OCRTesseract-OCR安装配置中文训练库引入依赖代码实