std::atomic<std::shared_ptr>
在标头 <memory> 定义
|
||
template< class T > struct std::atomic<std::shared_ptr<T>>; |
(C++20 起) | |
std::atomic 对 std::shared_ptr<T> 的部分模板特化允许用户原子地操纵 shared_ptr
对象。
若多个执行线程不同步地同时访问同一 std::shared_ptr 对象,且任何这些访问使用了 shared_ptr 的非 const 成员函数,则将出现数据竞争,除非通过 std::atomic<std::shared_ptr>> 的实例进行所有访问(或通过从 C++20 起弃用的孤立函数对 std::shared_ptr 进行原子访问)。
关联 use_count
的自增保证是原子操作的一部分。关联 use_count
的自减后序于原子操作,但不要求是原子操作的一部分,除非是在覆写失败的 CAS 中的 expected
时对 use_count
的更改。任何关联的删除和解分配都后序于原子更新步骤,且不是原子操作的一部分。
注意 shared_ptr
的控制块是线程安全的:多个线程能同时用可变操作,例如 operator= 或 reset,访问不同的非原子 std::shared_ptr 对象,即使这些实例互为副本,且于内部共享同一控制块也是如此。
类型 T
可为不完整类型。
成员类型
成员类型 | 定义 |
value_type
|
std::shared_ptr<T> |
成员函数
此特化提供所有非特化的 std::atomic 的成员函数,不提供附加成员函数。
constexpr atomic() noexcept = default; |
(1) | |
constexpr atomic( std::nullptr_t ) noexcept : atomic() {} |
(2) | |
atomic( std::shared_ptr<T> desired ) noexcept; |
(3) | |
atomic( const atomic& ) = delete; |
(4) | |
void operator=( const atomic& ) = delete; |
(1) | |
void operator=( std::shared_ptr<T> desired ) noexcept; |
(2) | |
void operator=( std::nullptr_t ) noexcept; |
(3) | |
bool is_lock_free() const noexcept; |
||
若此类型所有对象上的原子操作为免锁则返回 true,否则返回 false。
void store( std::shared_ptr<T> desired, std::memory_order order = std::memory_order_seq_cst ) noexcept; |
||
如同用 p.swap(desired),原子地以 desired 的值替换 *this 的值,其中 p 是底层的 std::shared_ptr<T>。按照 order 排序内存。若 order 是 std::memory_order_consume、std::memory_order_acquire 或 std::memory_order_acq_rel 则行为未定义。
std::shared_ptr<T> load( std::memory_order order = std::memory_order_seq_cst ) const noexcept; |
||
原子地返回底层共享指针的副本。按照 order 排序内存。若 order 是 std::memory_order_release 或 std::memory_order_acq_rel 则行为未定义。
std::shared_ptr<T> exchange( std::shared_ptr<T> desired, std::memory_order order = std::memory_order_seq_cst ) noexcept; |
||
如同用 p.swap(desired),原子地以 desired 替换底层 std::shared_ptr<T>,其中 p 为底层 std::shared_ptr<T>,并返回该 p 的值的副本。按照 order 排序内存。这是原子读修改写操作。
bool compare_exchange_strong( std::shared_ptr<T>& expected, std::shared_ptr<T> desired, std::memory_order success, std::memory_order failure ) noexcept; |
(1) | |
bool compare_exchange_weak( std::shared_ptr<T>& expected, std::shared_ptr<T> desired, std::memory_order success, std::memory_order failure ) noexcept; |
(2) | |
bool compare_exchange_strong( std::shared_ptr<T>& expected, std::shared_ptr<T> desired, std::memory_order order = std::memory_order_seq_cst ) noexcept; |
(3) | |
bool compare_exchange_weak( std::shared_ptr<T>& expected, std::shared_ptr<T> desired, std::memory_order order = std::memory_order_seq_cst ) noexcept; |
(4) | |
use_count
的更新是原子操作的一部分,尽管不要求写入自身(以及任何后继的解分配/析构)是其一部分。fail_order
与 order
相同,除了 std:memory_order_acq_rel 被替换为 std::memory_order_acquire,而 std::memory_order_release 被替换为 std::memory_order_relaxed。fail_order
与 order
相同,除了 std::memory_order_acq_rel 被替换为 std::memory_order_acquire 而 std::memory_order_release 被替换为 std::memory_order_relaxed。
void wait( std::shared_ptr<T> old, std::memory_order order = std::memory_order_seq_cst ) const noexcept; |
||
进行原子等待操作。
比较 load(order) 与 old,而若它们等价则阻塞直至 *this 被 notify_one()
或 notify_all()
提醒。重复此操作直至 load(order) 更改。此函数保证仅若值更改才返回,即使底层实现虚假地除阻也是如此。
按照 order 排序内存。若 order 为 std::memory_order_release 或 std::memory_order_acq_rel 则行为未定义。
注意:若两个 shared_ptr
存储同一指针,且要么共享所有权要么都为空,则它们等价。
void notify_one() noexcept; |
||
进行原子提醒操作。
若有一个线程在 *this 上的原子等待操作(即 wait()
)中阻塞,则除阻至少一个这种线程,否则不做任何事。
void notify_all() noexcept; |
||
进行原子提醒操作。
除阻所有在 *this 上的原子等待操作(即 wait()
)中阻塞的线程,若存在;否则不做任何事。
成员常量
此特化亦提供标准 std::atomic 仅有的成员常量 is_always_lock_free
。
static constexpr bool is_always_lock_free = /* 由实现定义 */; |
||
注解
功能特性测试宏 | 值 | 标准 | 功能特性 |
---|---|---|---|
__cpp_lib_atomic_shared_ptr |
201711L | (C++20) | std::atomic<std::shared_ptr>
|
示例
本节未完成 原因:暂无示例 |
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 3661 | C++20 | atomic<shared_ptr<T>> 不可从 nullptr 常量初始化
|
使之可常量初始化 |
LWG 3893 | C++20 | LWG3661 使得 atomic<shared_ptr<T>> 不能从 nullptr_t 赋值
|
恢复为可赋值 |
参阅
(C++11) |
atomic 类模板及其针对布尔、整数、浮点数 (C++20 起)和指针类型的特化 (类模板) |