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.");
});
//
CountDownLatch和CyclicBarrier是Java中用于线程同步的工具,前者用于等待其他线程完成,计数器递减至0后释放阻塞;后者则让一组线程在屏障点等待,所有线程到达后一起继续执行,常用于多阶段计算任务。示例代码展示了它们的基本用法。
830

被折叠的 条评论
为什么被折叠?



