使用Java的并发工具类:CountDownLatch和CyclicBarrier的使用

CountDownLatch和CyclicBarrier是Java并发工具类,用于在多线程环境下实现线程间的同步。它们都可以用于控制线程的执行顺序和等待其他线程的完成,但在使用方式和功能上有一些区别。

1. CountDownLatch(倒计时门闩):
   - CountDownLatch是一种同步工具类,它允许一个或多个线程等待其他线程完成操作。
   - CountDownLatch内部维护一个计数器,初始值可以设置为任意整数,每当一个线程完成操作时,计数器减1。
   - 主线程可以通过调用CountDownLatch的await()方法阻塞,直到计数器变为0。
   - 其他线程在完成任务后,调用CountDownLatch的countDown()方法,将计数器减1。
   - 应用场景:CountDownLatch常用于等待其他线程初始化完成、等待多个任务同时开始执行、等待多个任务完成等。

下面是CountDownLatch的简单示例:

```java
import java.util.concurrent.CountDownLatch;

public class CountDownLatchExample {
    public static void main(String[] args) throws InterruptedException {
        int threads = 5;
        CountDownLatch latch = new CountDownLatch(threads);

        for (int i = 0; i < threads; i++) {
            Thread thread = new Thread(() -> {
                // 执行任务
                // ...

                // 任务完成,计数器减1
                latch.countDown();
            });
            thread.start();
        }

        // 主线程等待计数器变为0
        latch.await();

        // 所有任务完成后继续执行
        System.out.println("All tasks completed.");
    }
}
```

2. CyclicBarrier(循环屏障):
   - CyclicBarrier也是一种同步工具类,它可以让一组线程在某个屏障处等待,然后继续执行。
   - CyclicBarrier内部维护一个计数器和一个屏障点,当线程到达屏障点时,调用await()方法等待其他线程。
   - 当所有线程都到达屏障点时,计数器会重置,所有线程同时继续执行。
   - CyclicBarrier可以设置一个可选的Runnable任务,在所有线程到达屏障点时执行该任务。
   - 应用场景:CyclicBarrier常用于多线程计算任务的分段执行,等待所有线程完成一段任务后再继续下一段任务。

下面是CyclicBarrier的简单示例:

```java
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;

public class CyclicBarrierExample {
    public static void main(String[] args) {
        int threads = 3;
        CyclicBarrier barrier = new CyclicBarrier(threads, () -> {
            // 所有线程到达屏障点后执行的任务
            System.out.println("All threads reached the barrier.");
        });


                    //

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值