std::atomic_wait, std::atomic_wait_explicit

< cpp‎ | atomic
 
 
 
定义于头文件 <atomic>
(1) (C++20 起)
template< class T >

void atomic_wait( const std::atomic<T>* object,

                  typename std::atomic<T>::value_type old ) noexcept;
template< class T >

void atomic_wait( const volatile std::atomic<T>* object,

                  typename std::atomic<T>::value_type old ) noexcept;
(2) (C++20 起)
template< class T >

void atomic_wait_explicit( const std::atomic<T>* object,
                           typename std::atomic<T>::value_type old,

                           std::memory_order order ) noexcept;
template< class T >

void atomic_wait_explicit( const volatile std::atomic<T>* object,
                           typename std::atomic<T>::value_type old,

                           std::memory_order order ) noexcept;

进行原子等待操作。表现为重复进行下列步骤:

  • 比较 object->load(std::memory_order_seq_cst)object->load(order)old值表示
    • 若它们逐位相等则阻塞直至 *thisstd::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::releasestd::memory_order::acq_rel

返回值

(无)

注解

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

由于 ABA 问题,可能错失从 old 到另一值再回到 old 的更改,而不除阻。

比较是逐位的(类似 std::memcpy );不使用比较运算符。忽略决不参与对象值表示的填充位。

示例

参阅

提醒至少一个在原子对象上的等待中阻塞的线程
(std::atomic<T> 的公开成员函数)
提醒所有在原子对象上的等待中阻塞的线程
(std::atomic<T> 的公开成员函数)
提醒一个在 atomic_wait 中阻塞的线程
(函数模板)
提醒所有在 atomic_wait 中阻塞的线程
(函数模板)