std::experimental::barrier

定义于头文件 <experimental/barrier>
class barrier;
(并发 TS)

std::experimental::barrier 提供线程协调机制,它允许参与线程阻塞直至操作完成。不同于 std::experimental::latch ,屏障可重用;一旦从屏障的同步点释放参与线程,则线程能重用同一屏障。

屏障拥有完成阶段,一旦参与线程集中度所有线程到达同步点,则参与线程之一执行完成阶段。 arrive_and_waitarrive_and_drop 的调用同步于完成阶段的起始;完成阶段的结束同步于从其完成所阻塞的所有调用返回。

对于 std::experimental::barrier ,完成阶段为空。 std::experimental::flex_barrier 允许用户以函数对象控制完成阶段。

num_threads 个线程构造的 barrier 的参与线程集,是在构造后首先到达其同步点的 num_threads 个线程。同一线程集(除了调用了 arrive_and_drop() 的线程)必须在 barrier 的每轮到达。

成员函数

构造 barrier
(公开成员函数)
销毁 barrier
(公开成员函数)
operator=
[被删除]
非可复制赋值
(公开成员函数)
到达同步点并阻塞
(公开成员函数)
到达同步点,并从参与线程集中移除当前线程
(公开成员函数)