std::experimental::flex_barrier
来自 cppreference.cn
< cpp | experimental
定义于头文件 <experimental/barrier> |
||
class flex_barrier; |
(并发 TS) | |
类 std::experimental::flex_barrier
提供了一种线程协调机制,允许一组参与线程阻塞,直到操作完成。与 std::experimental::latch
不同,barrier 是可重用的;一旦参与线程从 barrier 的同步点释放,它们可以重用同一个 barrier。
barrier 具有完成阶段,当所有参与线程到达同步点时,由其中一个参与线程执行。arrive_and_wait
和 arrive_and_drop
调用与完成阶段的开始同步;完成阶段的结束与所有被其完成阻塞的调用的返回同步。
std::experimental::flex_barrier
允许用户使用函数对象控制完成阶段。如果函数对象返回 -1,则参与线程集保持不变(并且同一组参与线程必须在下一个周期到达同步点);否则,参与线程集变为一个新集合,其大小等于返回值 N,并且由接下来到达 barrier 同步点的 N 个线程组成。
不需要此功能的用户可以使用 std::experimental::barrier
。
[编辑] 成员函数
构造一个 flex_barrier (公共成员函数) | |
销毁 flex_barrier (公共成员函数) | |
operator= [已删除] |
不可复制赋值 (公共成员函数) |
到达同步点并阻塞 (公共成员函数) | |
到达同步点并将当前线程从参与线程集中移除 (公共成员函数) |