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

在C++20中,std::latch 和 std::barrier 是两个新增的线程同步工具,它们用于协调多个线程之间的执行时机。相比传统的互斥锁和条件变量,它们更轻量、语义更清晰,特别适合用于“等待一组线程完成”或“阶段性同步”的场景。
std::latch 是一个一次性使用的同步机制,它维护一个内部计数器,初始值由构造函数指定。多个线程可以调用 count_down() 来减少计数,而其他线程可以调用 wait() 或 arrive_and_wait() 来阻塞,直到计数归零。
关键特性:
try_wait() 和带超时的等待,增加灵活性。示例:主线程启动5个线程,等待它们全部完成。
立即学习“C++免费学习笔记(深入)”;
#include <thread>
#include <vector>
#include <latch>
#include <iostream>
void worker(std::latch& latch) {
std::cout << "线程 " << std::this_thread::get_id()
<< " 完成工作\n";
latch.count_down();
}
int main() {
std::latch latch(5);
std::vector<std::thread> 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 与 latch 类似,但它支持重复使用。每当累计有 N 个线程到达屏障点(调用 arrive_and_wait()),所有线程被释放,并自动重置状态,可用于下一轮同步。
适用场景:
示例:4个线程进行两轮并行任务,每轮结束后同步。
#include <thread>
#include <barrier>
#include <iostream>
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();
}
两者都用于线程汇合,但用途不同:
基本上就这些。这两个工具让C++20的并发编程更现代、简洁,减少了手写条件变量的复杂性和出错概率。合理使用它们,能显著提升代码可读性和线程安全。不复杂但容易忽略的是:它们都不支持动态调整参与线程数量,设计时需提前确定协作规模。
以上就是c++++中的std::latch和std::barrier_c++20线程同步新工具的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号