CountDownLatch通过计数器实现线程同步,主线程等待多个子线程完成任务。初始化时设定计数值,每调用一次countDown()计数减1,await()使主线程阻塞直至计数为0。适用于主线程等待多线程初始化或并发任务完成等场景。示例中三个子线程执行完毕后调用countDown(),主线程被唤醒继续执行。支持超时等待避免无限阻塞,需注意计数器不可重置,应确保countDown()调用次数与初始值一致,建议在finally块中调用以保证计数准确。

在Java多线程编程中,CountDownLatch 是一个非常实用的同步工具类,它允许一个或多个线程等待其他线程完成操作后再继续执行。它的核心机制是基于一个计数器,当计数器归零时,所有被阻塞的线程将被释放。
CountDownLatch通过构造函数传入一个整数值,表示需要等待的事件数量。每调用一次 countDown() 方法,计数器减1。而调用 await() 的线程会一直阻塞,直到计数器变为0,或者等待超时。
常见使用场景包括:
下面是一个简单的例子,展示如何使用 CountDownLatch 让主线程等待三个工作线程完成任务:
立即学习“Java免费学习笔记(深入)”;
import java.util.concurrent.CountDownLatch;
public class CountDownLatchExample {
public static void main(String[] args) throws InterruptedException {
int threadCount = 3;
CountDownLatch latch = new CountDownLatch(threadCount);
for (int i = 1; i <= threadCount; i++) {
final int taskId = i;
new Thread(() -> {
System.out.println("任务 " + taskId + " 开始执行");
try {
Thread.sleep(2000); // 模拟耗时操作
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
System.out.println("任务 " + taskId + " 完成");
latch.countDown(); // 计数器减1
}).start();
}
System.out.println("主线程等待所有任务完成...");
latch.await(); // 阻塞直到计数器为0
System.out.println("所有任务已完成,主线程继续执行");
}
}
在这个例子中,主线程调用 latch.await() 后进入等待状态,三个子线程各自执行完成后调用 countDown(),当第三次调用后计数器归零,主线程被唤醒并继续执行。
如果你不希望线程无限等待,可以使用带超时参数的 await(long timeout, TimeUnit unit) 方法:
boolean finished = latch.await(5, TimeUnit.SECONDS);
if (finished) {
System.out.println("所有任务在5秒内完成");
} else {
System.out.println("等待超时,部分任务可能未完成");
}
这种方法适用于对响应时间有要求的场景,避免程序因某个线程卡住而长时间无响应。
使用 CountDownLatch 时需要注意以下几点:
基本上就这些。CountDownLatch 使用简单但功能强大,合理运用能有效协调线程之间的执行顺序,提升程序的可控性和稳定性。
以上就是如何利用Java实现CountDownLatch线程等待的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号