std::experimental::flex_barrier
< cpp | experimental
定义于头文件 <experimental/barrier>
|
||
class flex_barrier; |
(并发 TS) | |
类 std::experimental::flex_barrier
提供线程协调机制,允许参与线程的集合阻塞直至操作完成。不同于 std::experimental::latch ,屏障可重用;一旦从屏障的同步点释放参与线程,则它们能重用同一屏障。
屏障拥有完成阶段,一旦参与线程集中的所有线程都到达同步点,则由参与线程之一执行完成阶段。 arrive_and_wait
和 arrive_and_drop
的调用同步于完成阶段的开始;完成阶段的结束同步于从其完成所阻塞的所有调用返回。
std::experimental::flex_barrier
允许用户以函数对象控制完成阶段。若函数对象返回 -1 ,则不更改参与线程集(而下个循环中同一参与线程集必须抵达同步点);否则参与线程集变为拥有等于返回值 N
的新大小的集合,并由到达屏障同步点的下 N
个线程组成。
不需要此功能的用户能使用 std::experimental::barrier 。
成员函数
构造 flex_barrier (公开成员函数) | |
销毁 flex_barrier (公开成员函数) | |
operator= [被删除] |
非可复制赋值 (公开成员函数) |
到达同步点并阻塞 (公开成员函数) | |
到达同步点并从参与线程集中移除当前线程 (公开成员函数) |