std::experimental::atomic_weak_ptr<T>::compare_exchange_strong, std::experimental::atomic_weak_ptr<T>::compare_exchange_weak
bool compare_exchange_weak( std::weak_ptr<T>& expected, const std::weak_ptr<T>& desired, std::memory_order success, std::memory_order failure ) noexcept; |
(1) | |
bool compare_exchange_weak( std::weak_ptr<T>& expected, std::weak_ptr<T>&& desired, std::memory_order success, std::memory_order failure ) noexcept; |
(2) | |
bool compare_exchange_weak( std::weak_ptr<T>& expected, const std::weak_ptr<T>& desired, std::memory_order order = std::memory_order_seq_cst ) noexcept; |
(3) | |
bool compare_exchange_weak( std::weak_ptr<T>& expected, std::weak_ptr<T>&& desired, std::memory_order order = std::memory_order_seq_cst ) noexcept; |
(4) | |
bool compare_exchange_strong( std::weak_ptr<T>& expected, const std::weak_ptr<T>& desired, std::memory_order success, std::memory_order failure ) noexcept; |
(5) | |
bool compare_exchange_strong( std::weak_ptr<T>& expected, std::weak_ptr<T>&& desired, std::memory_order success, std::memory_order failure ) noexcept; |
(6) | |
bool compare_exchange_strong( std::weak_ptr<T>& expected, const std::weak_ptr<T>& desired, std::memory_order order = std::memory_order_seq_cst ) noexcept; |
(7) | |
bool compare_exchange_strong( std::weak_ptr<T>& expected, std::weak_ptr<T>&& desired, std::memory_order order = std::memory_order_seq_cst ) noexcept; |
(8) | |
原子地比较 *this 中底层的 weak_ptr
与 expected,如果它们等价,则用 desired 替换前者(执行读-改-写操作)。否则,将 *this 中存储的实际值加载到 expected 中(执行加载操作)。替换操作通过 weak_ptr
的复制或移动赋值运算符(视情况而定)执行。
当且仅当两个 weak_ptr
存储相同的指针值并共享所有权时,它们才等价。
读-改-写和加载操作的内存模型分别是 success 和 failure。对于重载 (3,4,7,8),order 用于读-改-写和加载操作,但如果 order == std::memory_order_acq_rel,则加载操作使用 std::memory_order_acquire;如果 order == std::memory_order_release,则加载操作使用 std::memory_order_relaxed。
弱版本 (1-4) 可能会虚假失败。
目录 |
[编辑] 参数
expected | - | 对原子对象中预期值的引用 |
desired | - | 如果原子对象符合预期,则存储到原子对象中的值 |
成功 | - | 如果比较成功,读-改-写操作的内存同步顺序。允许所有值 |
failure | - | 如果比较失败,加载操作的内存同步顺序。不能是 std::memory_order_release 或 std::memory_order_acq_rel,也不能指定比 success 更强的顺序 |
顺序 | - | 两个操作的内存同步顺序 |
[编辑] 返回值
如果底层原子值已更改,则为 true,否则为 false。
[编辑] 备注
对 atomic_weak_ptr
对象本身的所有更改以及所有相关的 use_count 增量都保证原子执行。相关的 use_count
减量在原子操作之后发生,但不需要作为其一部分。任何相关的销毁或解分配操作在原子操作之后发生,并且不作为其一部分。
如果比较-交换操作返回 true,则在原子更新步骤之后不会访问 expected。如果返回 false,则 expected 会更新为从尝试的原子更新中的 atomic_weak_ptr
对象读取的现有值。expected 的写入对应的 use_count
更新是原子操作的一部分,但 expected 的写入本身不要求是原子操作的一部分。
对于重载 (1,3,5,7),在原子更新步骤之后不访问 desired。
对于重载 (2,4,6,8),只有当比较-交换操作返回 true 时,才会从 desired 移动;移动发生在原子更新步骤之后。
[编辑] 注意
函数的弱形式 (1-4) 允许虚假失败,即即使 *this 和 expected 等价,也表现为不等价。当比较和交换在循环中时,弱版本在某些平台上会产生更好的性能。
[编辑] 另请参阅
特化 std::shared_ptr 的原子操作(函数模板) |