Java CyclicBarrier和CountDownLatch的区别

简介: Java CyclicBarrier和CountDownLatch的区别

Java CyclicBarrier和CountDownLatch的区别

在Java中,CyclicBarrier和CountDownLatch是用于多线程协作的工具类,它们都可以用于线程间的同步和等待,但在使用方式和场景上有一些区别。

CyclicBarrier(循环屏障):

  • CyclicBarrier用于让多个线程相互等待,直到达到某个公共的屏障点,然后同时开始执行下一阶段的任务。
  • CyclicBarrier可以重复使用,当所有线程都到达屏障点时,屏障会打开,所有线程可以继续执行后续任务。
  • CyclicBarrier适用于任务分阶段执行的场景,要求多个线程在同一时间点相互等待,并且可以同时开始下一阶段的任务。

代码示例:

CyclicBarrier barrier = new CyclicBarrier(3, () -> {
    // 当所有线程都到达屏障点时执行的任务
    System.out.println("All threads reached the barrier");
});

// 线程1
new Thread(() -> {
    // 线程1的任务
    try {
        Thread.sleep(1000);
        System.out.println("Thread 1 finished");
        barrier.await(); // 等待其他线程到达屏障点
    } catch (InterruptedException | BrokenBarrierException e) {
        e.printStackTrace();
    }
}).start();

// 线程2和线程3类似

// 输出:
// Thread 1 finished
// Thread 2 finished
// Thread 3 finished
// All threads reached the barrier

CountDownLatch(倒计时门闩):

  • CountDownLatch用于实现一个或多个线程等待其他线程执行完毕的场景。
  • CountDownLatch初始化一个计数器,每个线程执行完任务后将计数器减一,等待的线程调用await()方法等待计数器为零时继续执行。
  • CountDownLatch一旦计数器为零,无法重置,所有等待的线程将同时被释放。

代码示例:

CountDownLatch latch = new CountDownLatch(3);

// 线程1
new Thread(() -> {
    // 线程1的任务
    System.out.println("Thread 1 finished");
    latch.countDown(); // 计数器减一
}).start();

// 线程2和线程3类似

try {
    latch.await(); // 等待计数器为零
    System.out.println("All threads finished");
} catch (InterruptedException e) {
    e.printStackTrace();
}

// 输出:
// Thread 1 finished
// Thread 2 finished
// Thread 3 finished
// All threads finished

CyclicBarrier和CountDownLatch的区别:

  • CyclicBarrier适合线程间等待彼此达到屏障点,然后同时开始下一阶段的任务,可以重复使用。而CountDownLatch适合一个或多个线程等待其他线程执行完毕后再继续执行,计数器无法重置。
  • CyclicBarrier更适合多阶段任务的协作,而CountDownLatch更适合某个任务的前置准备或者等待多个任务同时完成的场景。

根据具体的业务需求和协作场景,选择合适的同步工具类可以提高程序的可读性和可维护性。

相关文章
|
9天前
|
Java
Java基础之 JDK8 HashMap 源码分析(中间写出与JDK7的区别)
这篇文章详细分析了Java中HashMap的源码,包括JDK8与JDK7的区别、构造函数、put和get方法的实现,以及位运算法的应用,并讨论了JDK8中的优化,如链表转红黑树的阈值和扩容机制。
13 1
|
13天前
|
Java 编译器 C语言
【一步一步了解Java系列】:探索Java基本类型与C语言的区别
【一步一步了解Java系列】:探索Java基本类型与C语言的区别
32 2
|
13天前
|
存储 缓存 Java
【用Java学习数据结构系列】HashMap与TreeMap的区别,以及Map与Set的关系
【用Java学习数据结构系列】HashMap与TreeMap的区别,以及Map与Set的关系
27 1
|
18天前
|
自然语言处理 Java 数据处理
Java IO流全解析:字节流和字符流的区别与联系!
Java IO流全解析:字节流和字符流的区别与联系!
44 1
|
18天前
|
缓存 安全 Java
Java中 final、finally、finalize 有什么区别?
本文详细阐述了Java中`final`、`finally`和`finalize`的区别:`final`用于修饰类、方法和变量以表示不可变性;`finally`是用于确保在`try-catch`结构中无论是否发生异常都能执行的代码块;而`finalize`是`Object`类的方法,用于在对象被垃圾回收前执行清理工作,但在JDK 9中已被标记为弃用。
14 0
Java中 final、finally、finalize 有什么区别?
|
18天前
|
Java
Java中抽象类和接口有什么区别?
本文阐述了Java中抽象类和接口的区别,包括类型扩展、方法/属性访问控制符、方法实现、使用目的等方面的不同,并提供了抽象类和接口的使用示例,以及Java中其他类型的类(普通类、内部类等)的简介。
17 0
Java中抽象类和接口有什么区别?
|
2天前
|
缓存 算法 Java
Java 中线程和纤程Fiber的区别是什么?
【10月更文挑战第14天】
10 0
|
4月前
|
API
java-多线程-CountDownLatch(闭锁) CyclicBarrier(栅栏) Semaphore(信号量)-
java-多线程-CountDownLatch(闭锁) CyclicBarrier(栅栏) Semaphore(信号量)-
30 1
|
Java
java多线程 -- CountDownLatch 闭锁
CountDownLatch 一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。 用给定的计数 初始化 CountDownLatch。由于调用了 countDown() 方法,所以在当前计数到达零之前,await 方法会一直受阻塞。
1006 0
|
4天前
|
安全 Java UED
Java中的多线程编程:从基础到实践
本文深入探讨了Java中的多线程编程,包括线程的创建、生命周期管理以及同步机制。通过实例展示了如何使用Thread类和Runnable接口来创建线程,讨论了线程安全问题及解决策略,如使用synchronized关键字和ReentrantLock类。文章还涵盖了线程间通信的方式,包括wait()、notify()和notifyAll()方法,以及如何避免死锁。此外,还介绍了高级并发工具如CountDownLatch和CyclicBarrier的使用方法。通过综合运用这些技术,可以有效提高多线程程序的性能和可靠性。