Java多线程协作:CyclicBarrier详解教程
时间:2026-02-08 14:23:37 146浏览 收藏
本篇文章给大家分享《Java多线程协作:CyclicBarrier使用详解》,覆盖了文章的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。
CyclicBarrier适用于固定数量线程必须全部到达后才一起继续执行的协作场景;它可重复使用,所有线程在屏障点同时唤醒,而CountDownLatch是一次性单向等待工具。

直接说结论:CyclicBarrier 适合「固定数量线程必须全部到达后才一起继续执行」的协作场景,不是用来替代 join 或 CountDownLatch 的万能工具。
什么时候该用 CyclicBarrier 而不是 CountDownLatch
CountDownLatch 是一次性倒计时,触发后不可重用;CyclicBarrier 支持重复使用,且所有等待线程会在屏障点「同时被唤醒并继续运行」——这是关键区别。
常见误用:用 CyclicBarrier 等待一个后台任务完成(比如只启动 1 个线程去干活,其余 4 个空等)。这违背设计意图,应改用 CountDownLatch 或 CompletableFuture。
- ✔ 正确场景:多个线程各自计算一部分数据,全部算完再合并结果(如分片矩阵乘法、并行归并排序)
- ✔ 正确场景:模拟多玩家游戏中的“准备就绪”阶段,5 个玩家线程都调用
await()后才开始下一回合 - ✘ 错误场景:主线程等子线程执行完某个异步操作——这不是「彼此等待」,而是「单向等待」
CyclicBarrier 构造与 await() 的典型用法
构造时指定参与线程总数,可选传入一个 Runnable 作为「屏障动作」——它由**最后一个到达的线程**执行,且在其他线程被释放前完成。
调用 await() 可能抛出 InterruptedException 或 BrokenBarrierException,必须处理。后者表示屏障已被中断或重置,后续调用会立即失败。
int partySize = 3;
CyclicBarrier barrier = new CyclicBarrier(partySize, () -> {
System.out.println("所有线程已就位,执行汇总逻辑");
});
// 每个线程中
try {
doWork();
barrier.await(); // 阻塞直到全部到达
afterBarrierAction();
} catch (InterruptedException | BrokenBarrierException e) {
// 必须处理,不能忽略
Thread.currentThread().interrupt();
}
容易踩的坑:重入、中断与重置行为
CyclicBarrier 的「可循环」不等于「自动重置」——它在一次所有线程通过后自动进入下一轮等待,但一旦发生中断或某线程超时未到,屏障就进入 broken 状态,后续调用 await() 会直接抛 BrokenBarrierException。
- 调用
reset()会强制清空当前状态,但正在阻塞的线程会收到BrokenBarrierException,需确保调用方能安全处理 - 如果某个线程在
await()时被interrupt(),整个屏障立刻 broken,其他线程即使没超时也会抛异常 - 不要在屏障动作(
Runnable)里做耗时操作,否则会拖慢所有线程的释放时机 await(long, TimeUnit)超时后同样导致屏障 broken,除非你显式调用reset()
真正难处理的是 broken 状态的传播和恢复逻辑——很多业务代码只捕获异常却没重置屏障,导致后续轮次直接失败。这点比 CountDownLatch 的单次语义复杂得多。
终于介绍完啦!小伙伴们,这篇关于《Java多线程协作:CyclicBarrier详解教程》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
369 收藏
-
371 收藏
-
302 收藏
-
431 收藏
-
444 收藏
-
399 收藏
-
317 收藏
-
375 收藏
-
129 收藏
-
218 收藏
-
466 收藏
-
229 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习