0

0

C++ 屏障(std::barrier)是什么?(如何同步多个线程的阶段性任务)

冰火之心

冰火之心

发布时间:2026-02-13 11:46:55

|

754人浏览过

|

来源于php中文网

原创

std::barrier是c++20引入的可重用线程同步原语,用于让一组线程在指定点集体等待直至全部到达后才一同继续;与一次性使用的std::latch不同,它支持多轮复用,构造时需指定非零预期线程数,且无超时机制。

c++ 屏障(std::barrier)是什么?(如何同步多个线程的阶段性任务)

std::barrier 是什么,和 std::latch 有什么区别

它是一个线程同步原语,用来让一组线程在某个点“集体等待”,直到所有线程都到达(arrive)后才一起放行。和 std::latch 不同,std::barrier 可重用——一次 wait 返回后,内部计数自动重置,下一轮还能继续用;而 std::latch 是一次性消耗品。

常见错误现象:想反复等多轮线程汇合,却用了 std::latch,结果第二轮调用 wait() 直接卡死或未定义行为。

  • 适用场景:并行计算中的迭代式任务(比如每轮做局部计算 → 同步 → 汇总 → 下一轮)
  • std::barrier 构造时必须指定参与线程数(expected),不能为 0 或负数,否则抛 std::invalid_argument
  • 如果某线程在 arrive() 前就退出(比如异常或 return),会导致其他线程永久阻塞——没有超时机制,也没办法“取消”等待

怎么正确初始化和触发 barrier 等待

构造时传入预期线程数,每个线程调用 arrive()arrive_and_wait()。后者是原子操作:先抵达、再阻塞、等全员齐后才返回。

性能影响:每次 arrive_and_wait() 都涉及原子计数和条件变量唤醒,频繁调用(如每微秒一次)会明显拖慢吞吐;若只是通知“我到了”,用 arrive() 更轻量。

立即学习C++免费学习笔记(深入)”;

腾讯云AI代码助手
腾讯云AI代码助手

基于混元代码大模型的AI辅助编码工具

下载
  • 推荐写法:barrier.arrive_and_wait() —— 简洁、不易漏掉 wait
  • 不推荐在循环里混用 arrive()wait(),容易因顺序错乱导致死锁
  • 如果需要在等待时执行回调(比如汇总数据),构造时传入一个可调用对象,它会在最后一个线程抵达、但尚未唤醒其余线程前执行——注意:此时其他线程仍处于阻塞中,回调里别做耗时或加锁操作

为什么 barrier.wait() 有时卡住不动

最常见原因是线程数量对不上:构造时写了 4,但实际只启动了 3 个线程调用 arrive(),第 4 个根本不存在,那剩下 3 个就永远等不到“第 4 个”。

另一个隐蔽坑:线程函数里没捕获异常,导致某个线程在抵达 barrier 前崩溃退出,等同于“少一人到场”。

  • 检查方式:在每个线程入口打日志,确认 arrive_and_wait() 确实被执行到
  • 不要依赖主线程“数着线程数启动”,改用 std::vector<:thread></:thread> 显式管理,并确保每个 join() 前都完成 barrier 同步
  • Windows 上某些旧版 MSVC(如 19.29 之前)对 std::barrier 实现有 bug,表现为虚假唤醒或 hang,建议升级到 19.30+

std::barrier 在 C++17/20 中的可用性与替代方案

std::barrier 是 C++20 引入的,C++17 及更早标准里没有。如果你用的是 GCC 10+、Clang 12+ 或较新 MSVC,且编译选项开了 -std=c++20,就能直接用。

兼容性 fallback 方案有限:不能简单用 std::mutex + std::condition_variable 手写一个完全等价的可重用 barrier(因为要精确控制唤醒时机和避免 spurious wakeups),但可以用 std::latch 模拟单次 barrier(需每次 new 一个新对象)。

  • 跨平台项目若暂不支持 C++20,建议封装一层宏判断:#if __cpp_lib_barrier >= 201907L
  • 别试图用 std::semaphore 替代——它无法保证“全员到齐才放行”,只能控并发数
  • 真实项目中,比 barrier 更常被忽略的是线程生命周期管理:barrier 对象本身必须活过所有线程的最后一次 arrive(),否则析构时可能引发 UB
事情说清了就结束

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

807

2023.08.22

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

673

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1068

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1145

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

818

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

460

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2358

2023.08.08

windows自动更新
windows自动更新

Windows操作系统的自动更新功能可以确保系统及时获取最新的补丁和安全更新,以提高系统的稳定性和安全性。然而,有时候我们可能希望暂时或永久地关闭Windows的自动更新功能。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

850

2023.08.10

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.3万人学习

C 教程
C 教程

共75课时 | 4.7万人学习

C++教程
C++教程

共115课时 | 17.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号