std::experimental::flex_barrier

来自cppreference.com
在标头 <experimental/barrier> 定义
class flex_barrier;
(并发 TS)

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

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

std::experimental::flex_barrier 允许用户以一个函数对象控制完成阶段。若函数对象返回 -1,则不更改参与线程集合(而下个循环中同一参与线程集合必须抵达同步点);否则参与线程集合变为拥有等于返回值 N 的新大小的集合,并由到达屏障同步点的下 N 个线程组成。

不需要此功能的用户可以使用 std::experimental::barrier

成员函数

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