JUC工具类: CyclicBarrier详解

简介: `CyclicBarrier`是并发编程领域一个非常实用的同步辅助类,适用于并行任务场景,它提供了一种简便的线程同步机制。正确地理解和使用这个工具,对开发者来说,可以大大简化并行处理逻辑的复杂度,增强代码的健壮性与可维护性。

在并发编程的领域,Java的 CyclicBarrier是一个同步辅助类,用于管理一组线程之间的合作流程,确保这些线程在继续执行之前达到一个公共的屏障点。这是一种非常有用的工具,特别适合于处理并行任务,在所有相关任务必须互相等待对方到达某一个点后才能继续执行的情况。

CyclicBarrier,顾名思义,循环使用的屏障。它允许一组线程互相等待,直到所有线程都达到了共同的屏障点(Barrier Point),在此之后,这些线程可以选择继续执行或执行某种公共的动作。与之类似的同步辅助类是 CountDownLatch,然而不同的是,CyclicBarrier可以在达到屏障时重置,所以它可以被重新使用。

特点和用法

  1. 屏障触发执行CyclicBarrier支持一个可选的 Runnable命令,在屏障点上,当给定数量的参与线程都到达了后,该命令只会被执行一次,常被用作聚合任务或更新共享状态。
  2. 线程参与数量:在构造 CyclicBarrier的时候,你需要指定等待的线程数量。只有当足够数量的线程都执行了 await()调用时,屏障才会打开,线程才能继续执行。
  3. 循环使用:与 CountDownLatch一次性的特性不同,CyclicBarrier可以通过其 reset()方法重置屏障,以便同一组线程可以多次使用它。
  4. 超时与中断CyclicBarrierawait()方法支持超时参数和可以响应中断。如果任一线程 await()期间被中断,或者等待超时,所有正在等待的线程都将通过 BrokenBarrierException异常来响应这种情况。

实践场景

常见的使用案例包括并行计算逻辑,其中多个子任务在继续执行下一步之前必须等待对方完成。例如,在多个玩家的游戏中,可能需要等待所有玩家都做好准备,或者在科学计算中,涉及多步骤的计算,每一步都依赖于前一步的结果。

示例代码

import java.util.concurrent.CyclicBarrier;

public class CyclicBarrierExample {
    // 在这里,假定屏障打开之前,需要有3个线程到达。
    private static final int PARTIES = 3;
    private static final CyclicBarrier barrier = new CyclicBarrier(PARTIES, 
        new Runnable() {
            // 当所有线程到达屏障时,首先执行的动作。
            public void run() {
                System.out.println("所有线程已到达屏障点,屏障现在开放,准备执行接下来的动作。");
            }
        }
    );

    public static void main(String[] args) {
        for (int i = 0; i < PARTIES; i++) {
            new Thread(new Worker(i)).start();
        }
    }

    static class Worker implements Runnable {
        private final int threadNumber;

        Worker(int threadNumber) {
            this.threadNumber = threadNumber;
        }

        public void run() {
            System.out.println("线程 " + threadNumber + " 正在工作。");
            try {
                // 该线程完成工作后,等待其他线程到达屏障点
                CyclicBarrierExample.barrier.await();
            } catch (Exception e) {
                e.printStackTrace();
            }
            System.out.println("线程 " + threadNumber + " 完成了等待,继续执行它的任务。");
        }
    }
}

在这段代码中,我们定义了一个 Worker内部类,模拟的是到达屏障点的线程执行体。一个 CyclicBarrier实例被创建,设置了必须有3个线程达到屏障点之后才能触发屏障打开的机制,并在屏障触发时输出相应信息。每个线程在到达屏障点后,等待 barrier.await()直到其他线程也到达,然后所有线程会几乎同时继续执行。

结论

CyclicBarrier是并发编程领域一个非常实用的同步辅助类,适用于并行任务场景,它提供了一种简便的线程同步机制。正确地理解和使用这个工具,对开发者来说,可以大大简化并行处理逻辑的复杂度,增强代码的健壮性与可维护性。

目录
相关文章
|
消息中间件 监控 Java
JUC第二十六讲:JUC工具类: CountDownLatch详解
JUC第二十六讲:JUC工具类: CountDownLatch详解
|
2月前
|
Java 数据库
JUC工具类: Semaphore详解
信号量Semaphore是并发编程中的一种高级同步机制,它可以在复杂的资源共享场景中发挥重要作用。理解它的工作原理及正确的使用方法对实现高效且健壮的并发控制至关重要。
27 1
|
3月前
|
Java
JUC工具类: CountDownLatch详解
`CountDownLatch`是并发编程实践中的一个重要工具,它能简化多线程协调执行的复杂性,特别是在当一个操作需要等待一个或多个事件完成才能继续执行时。使用 `CountDownLatch`可以编写简洁的并行代码,确保在执行操作之前,所有的必要步骤都已经准备就绪。
27 1
|
6月前
|
Java
JUC 常用 4 大并发工具类 CountDownLatch、CyclicBarrier、Semaphore、ExChanger
JUC 常用 4 大并发工具类 CountDownLatch、CyclicBarrier、Semaphore、ExChanger
|
缓存 安全 Java
JUC第三十讲:JUC工具类:Exchanger详解
JUC第三十讲:JUC工具类:Exchanger详解
119 1
JUC第二十七讲:JUC工具类: CyclicBarrier详解
JUC第二十七讲:JUC工具类: CyclicBarrier详解
JUC第二十八讲:JUC工具类: Semaphore详解
JUC第二十八讲:JUC工具类: Semaphore详解
|
监控
JUC第二十九讲:JUC工具类: Phaser详解
JUC第二十九讲:JUC工具类: Phaser详解
|
存储 安全 Java
一天一个 JUC 工具类 -- AQS
AbstractQueuedSynchronizer(AQS)是Java中用于构建锁和同步器的抽象基类。它是Java并发工具包(java.util.concurrent)中实现高级线程同步控制的关键组件之一。AQS提供了一种基于等待队列的同步器框架,允许开发者构建自定义的同步器。在这篇文章中我们将从源码分析和底层原理的角度来介绍AQS。
|
安全 Dubbo Java
JUC系列(七)| JUC三大常用工具类CountDownLatch、CyclicBarrier、Semaphore
JUC系列(七)| JUC三大常用工具类CountDownLatch、CyclicBarrier、Semaphore
458 0
JUC系列(七)| JUC三大常用工具类CountDownLatch、CyclicBarrier、Semaphore