std::experimental::barrier
来自cppreference.com
< cpp | experimental
在标头 <experimental/barrier> 定义
|
||
class barrier; |
(并发 TS) | |
类 std::experimental::barrier
提供一种线程协调机制,它允许参与线程阻塞直至操作完成。不同于 std::experimental::latch,屏障可以重用;一旦从屏障的同步点释放参与线程,线程就能重用同一屏障。
屏障拥有完成阶段,一旦参与线程集合中的所有线程均到达同步点,则由参与线程之一执行完成阶段。arrive_and_wait
和 arrive_and_drop
的调用同步于完成阶段的开始;完成阶段的结束同步于从阻塞于其完成的所有调用的返回。
对于 std::experimental::barrier
,完成阶段为空。std::experimental::flex_barrier 允许用户以一个函数对象控制其完成阶段。
为 num_threads
个线程构造的 barrier
的参与线程集合,是在构造后首先到达其同步点的 num_threads
个线程。同一线程集合(除了调用了 arrive_and_drop()
的线程)必须在每轮都到达此 barrier
。
成员函数
构造 barrier (公开成员函数) | |
销毁 barrier (公开成员函数) | |
operator= [弃置] |
非可复制赋值 (公开成员函数) |
到达同步点并阻塞 (公开成员函数) | |
到达同步点,并从参与线程集合中移除当前线程 (公开成员函数) |