命名空间
变体
操作

std::atomic_flag::wait

来自 cppreference.cn
< cpp‎ | atomic‎ | atomic flag
 
 
并发支持库
线程
(C++11)
(C++20)
this_thread 命名空间
(C++11)
(C++11)
(C++11)
协同取消
互斥
(C++11)
通用锁管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
条件变量
(C++11)
信号量
闩锁和屏障
(C++20)
(C++20)
期物
(C++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
Hazard 指针
原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中已弃用)
(C++11)(C++20 中已弃用)
内存顺序
(C++11)(C++26 中已弃用)
原子操作的自由函数
原子标志的自由函数
 
 
void wait( bool old, std::memory_order order =
                         std::memory_order_seq_cst ) const noexcept;
(1) (自 C++20 起)
(constexpr 自 C++26 起)
void wait( bool old,

           std::memory_order order =

               std::memory_order_seq_cst ) const volatile noexcept;
(2) (自 C++20 起)

执行原子等待操作。行为如同重复执行以下步骤

  • this->test(order)old 的结果进行比较。
    • 如果结果相等,则阻塞,直到 *thisnotify_one()notify_all() 通知,或者线程被伪唤醒。
    • 否则,返回。

即使底层实现发生伪唤醒,这些函数也保证仅在值已更改时返回。

如果 order 不是 std::memory_order_relaxed, std::memory_order_consume, std::memory_order_acquirestd::memory_order_seq_cst,则行为未定义。

目录

[编辑] 参数

old - 要检查 atomic_flag 对象不再包含的值
order - 要强制执行的内存顺序约束

[编辑] 注意

这种形式的更改检测通常比简单的轮询或纯自旋锁更有效。

由于 ABA 问题,从 old 到另一个值再返回到 old 的瞬态更改可能会被错过,并且不会解除阻塞。


[编辑] 示例

[编辑] 参见

通知至少一个等待原子对象的线程
(公共成员函数) [编辑]
通知所有阻塞并等待原子对象的线程
(公共成员函数) [编辑]
通知在 atomic_flag_wait 中阻塞的线程
(函数) [编辑]
通知所有在 atomic_flag_wait 中阻塞的线程
(函数) [编辑]