0

0

c++中的std::latch和std::barrier_c++20线程同步新工具

穿越時空

穿越時空

发布时间:2025-12-16 15:09:32

|

308人浏览过

|

来源于php中文网

原创

std::latch用于一次性线程同步,如主线程等待多线程完成;std::barrier支持重复使用,适用于多阶段并行计算的周期性同步,两者均提升C++20并发编程的简洁性与安全性。

c++中的std::latch和std::barrier_c++20线程同步新工具

在C++20中,std::latchstd::barrier 是两个新增的线程同步工具,它们用于协调多个线程之间的执行时机。相比传统的互斥锁和条件变量,它们更轻量、语义更清晰,特别适合用于“等待一组线程完成”或“阶段性同步”的场景。

std::latch:一次性倒计时门闩

std::latch 是一个一次性使用的同步机制,它维护一个内部计数器,初始值由构造函数指定。多个线程可以调用 count_down() 来减少计数,而其他线程可以调用 wait()arrive_and_wait() 来阻塞,直到计数归零。

关键特性:

  • 只能使用一次,一旦计数归零,所有等待线程被释放,之后不能再重置。
  • 常用于主线程等待多个工作线程完成任务的场景。
  • 支持 try_wait() 和带超时的等待,增加灵活性。

示例:主线程启动5个线程,等待它们全部完成。

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

#include 
#include 
#include 
#include 

void worker(std::latch& latch) {
    std::cout << "线程 " << std::this_thread::get_id() 
              << " 完成工作\n";
    latch.count_down();
}

int main() {
    std::latch latch(5);
    std::vector threads;

    for (int i = 0; i < 5; ++i) {
        threads.emplace_back(worker, std::ref(latch));
    }

    latch.wait(); // 等待5个线程都调用 count_down()
    std::cout << "所有线程已完成。\n";

    for (auto& t : threads) t.join();
}

std::barrier:可重复使用的屏障

std::barrier 与 latch 类似,但它支持重复使用。每当累计有 N 个线程到达屏障点(调用 arrive_and_wait()),所有线程被释放,并自动重置状态,可用于下一轮同步。

Asksia
Asksia

Asksia AI - 最好的AI老师,可靠的作业助手

下载

适用场景:

  • 多阶段并行计算,如迭代算法中的每轮同步。
  • 需要周期性等待所有线程汇合的情况。
  • 支持在最后一个到达的线程上执行“阶段完成”回调函数(通过构造时传入)。

示例:4个线程进行两轮并行任务,每轮结束后同步。

#include 
#include 
#include 

void stage_worker(int id, std::barrier<>& phase) {
    std::cout << "线程 " << id << " 完成第一阶段\n";
    phase.arrive_and_wait();

    std::cout << "线程 " << id << " 完成第二阶段\n";
    phase.arrive_and_wait();
}

int main() {
    std::barrier barrier(4); // 需要4个线程同步

    std::thread t1(stage_worker, 1, std::ref(barrier));
    std::thread t2(stage_worker, 2, std::ref(barrier));
    std::thread t3(stage_worker, 3, std::ref(barrier));
    std::thread t4(stage_worker, 4, std::ref(barrier));

    t1.join(); t2.join(); t3.join(); t4.join();
}

latch vs barrier:如何选择?

两者都用于线程汇合,但用途不同:

  • std::latch 当你只需要一次等待,比如启动后等待初始化完成,或任务结束前汇总结果。
  • std::barrier 当你需要多次同步,比如循环并行处理、分阶段计算等。
  • latch 更简单,barrier 功能更强,但开销略高。

基本上就这些。这两个工具让C++20的并发编程更现代、简洁,减少了手写条件变量的复杂性和出错概率。合理使用它们,能显著提升代码可读性和线程安全。不复杂但容易忽略的是:它们都不支持动态调整参与线程数量,设计时需提前确定协作规模。

相关专题

更多
线程和进程的区别
线程和进程的区别

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

482

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

143

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

5

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

11

2026.01.21

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

143

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

5

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

11

2026.01.21

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

404

2023.08.14

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

7

2026.01.23

热门下载

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

精品课程

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

共28课时 | 3.4万人学习

Excel 教程
Excel 教程

共162课时 | 13万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

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

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