C++ 参考手册
- C++11
- C++14
- C++17
- C++20
- C++ 编译器支持情况表
- 独立与宿主实现
- C++ 语言
- C++ 关键词
- 预处理器
- C++ 标准库头文件
- 具名要求
- 功能特性测试 (C++20)
- 工具库
- 类型支持(基本类型、RTTI、类型特性)
- 概念库 (C++20)
- 错误处理
- 动态内存管理
- 日期和时间工具
- 字符串库
- 容器库
- 迭代器库
- 范围库 (C++20)
- 算法库
- 数值库
- 输入/输出库
- 文件系统库
- 本地化库
- 正则表达式库
- 原子操作库
- std::atomic_store, std::atomic_store_explicit
- std::atomic_load, std::atomic_load_explicit
- std::atomic_exchange, std::atomic_exchange_explicit
- std::atomic
- std::atomic_flag
- std::atomic_ref
- std::atomic_compare_exchange_weak, std::atomic_compare_exchange_strong, std::atomic_compare_exchange_weak_explicit, std::atomic_compare_exchange_strong_explicit
- std::atomic_fetch_add, std::atomic_fetch_add_explicit
- std::atomic_fetch_sub, std::atomic_fetch_sub_explicit
- std::atomic_fetch_and, std::atomic_fetch_and_explicit
- std::atomic_fetch_or, std::atomic_fetch_or_explicit
- std::atomic_fetch_xor, std::atomic_fetch_xor_explicit
- std::atomic_is_lock_free, ATOMIC_xxx_LOCK_FREE
- std::atomic_wait, std::atomic_wait_explicit
- std::atomic_notify_one
- std::atomic_notify_all
- std::atomic_flag_test_and_set, std::atomic_flag_test_and_set_explicit
- std::atomic_flag_clear, std::atomic_flag_clear_explicit
- std::atomic_flag_test, std::atomic_flag_test_explicit
- std::atomic_flag_wait, std::atomic_flag_wait_explicit
- std::atomic_flag_notify_one
- std::atomic_flag_notify_all
- std::atomic_init
- ATOMIC_VAR_INIT
- ATOMIC_FLAG_INIT
- std::memory_order
- std::kill_dependency
- std::atomic_thread_fence
- std::atomic_signal_fence
- 注释
- 线程支持库
- 实验性 C++ 特性
- 有用的资源
- 索引
- std 符号索引
- 协程支持 (C++20)
- C++ 关键词
std::atomic_wait, std::atomic_wait_explicit
定义于头文件 <atomic>
|
||
(1) | (C++20 起) | |
template< class T > void atomic_wait( const std::atomic<T>* object, |
||
template< class T > void atomic_wait( const volatile std::atomic<T>* object, |
||
(2) | (C++20 起) | |
template< class T > void atomic_wait_explicit( const std::atomic<T>* object, |
||
template< class T > void atomic_wait_explicit( const volatile std::atomic<T>* object, |
||
进行原子等待操作。表现为重复进行下列步骤:
- 比较 object->load(std::memory_order_seq_cst) 或 object->load(order) 与
old
的值表示。- 若它们逐位相等则阻塞直至 *this 被 std::atomic::notify_one() 或 std::atomic::notify_all() 提醒,或线程被虚假地除阻。
- 否则返回。
允许这些函数虚假地除阻,即由于值更改或提醒之外的原因返回。
1) 等价于 object->wait(old, std::memory_order_seq_cst) 。
2) 等价于 object->wait(old, order) 。
参数
object | - | 指向要检查并在其上等待的原子对象的指针 |
old | - | 要检测的原子对象不再含有的值 |
order | - | 此操作所用的内存同步顺序:必须不是 std::memory_order::release 或 std::memory_order::acq_rel |
返回值
(无)
注解
更改检测的这种形式通常比简单轮询或纯自旋锁高效。
由于 ABA 问题,可能错失从 old
到另一值再回到 old
的更改,而不除阻。
比较是逐位的(类似 std::memcpy );不使用比较运算符。忽略决不参与对象值表示的填充位。
示例
本节未完成 原因:暂无示例 |
参阅
(C++20) |
提醒至少一个在原子对象上的等待中阻塞的线程 ( std::atomic<T> 的公开成员函数) |
(C++20) |
提醒所有在原子对象上的等待中阻塞的线程 ( std::atomic<T> 的公开成员函数) |
(C++20) |
提醒一个在 atomic_wait 中阻塞的线程 (函数模板) |
(C++20) |
提醒所有在 atomic_wait 中阻塞的线程 (函数模板) |