std::atomic_flag_wait, std::atomic_flag_wait_explicit
来自 cppreference.com
定义在头文件 <atomic> 中 |
||
void atomic_flag_wait( const atomic_flag* object, bool old ) noexcept; |
(1) | (自 C++20) |
void atomic_flag_wait( const volatile atomic_flag* object, bool old ) noexcept; |
(2) | (自 C++20) |
void atomic_flag_wait_explicit( const atomic_flag* object, bool old, std::memory_order order ) noexcept; |
(3) | (自 C++20) |
void atomic_flag_wait_explicit( const volatile atomic_flag* object, bool old, std::memory_order order ) noexcept; |
(4) | (自 C++20) |
执行原子等待操作。
将 object->test(std::memory_order_seq_cst) 或 object->test(order) 与 old 进行比较,如果相等,则阻塞,直到 *object 被 std::atomic_flag::notify_one() 或 std::atomic_flag::notify_all()(或线程被虚假地解除阻塞)通知。这会重复,直到值比较不相等。
1,2) 内存同步顺序是 std::memory_order_seq_cst。
3,4) 内存同步顺序是 order。
这些函数保证仅在值发生更改时才返回,即使底层实现虚假地解除阻塞也是如此。
内容 |
[编辑] 参数
object | - | 指向要检查和等待的原子标志的指针 |
old | - | 要检查原子标志不再包含的值 |
order | - | 内存同步排序 |
[编辑] 返回值
(无)
[编辑] 注释
这种变化检测形式通常比简单的轮询或纯自旋锁更有效。
由于 ABA 问题,从 old 到另一个值再回到 old 的瞬态变化可能会被忽略,并且不会解除阻塞。
[编辑] 示例
本节不完整 原因:没有示例 |
[编辑] 另请参见
(C++20) |
通知至少一个正在等待原子对象的线程 ( std::atomic_flag 的公共成员函数) |
(C++20) |
通知所有阻塞等待原子对象的线程 ( std::atomic_flag 的公共成员函数) |
(C++20) |
通知在 atomic_flag_wait 中阻塞的线程 (函数) |
(C++20) |
通知在 atomic_flag_wait 中阻塞的所有线程 (函数) |