std::atomic_...<std::shared_ptr>

来自cppreference.com
< cpp‎ | memory‎ | shared ptr
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)

 
动态内存管理
未初始化内存算法
受约束的未初始化内存算法
分配器
垃圾收集器支持
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)



 
 
在标头 <memory> 定义
template< class T >
bool atomic_is_lock_free( const std::shared_ptr<T>* p );
(1) (C++11 起)
(C++20 中弃用)
(C++26 中移除)
template< class T >
std::shared_ptr<T> atomic_load( const std::shared_ptr<T>* p );
(2) (C++11 起)
(C++20 中弃用)
(C++26 中移除)
template< class T >

std::shared_ptr<T> atomic_load_explicit

    ( const std::shared_ptr<T>* p, std::memory_order mo );
(3) (C++11 起)
(C++20 中弃用)
(C++26 中移除)
template< class T >
void atomic_store( std::shared_ptr<T>* p, std::shared_ptr<T> r );
(4) (C++11 起)
(C++20 中弃用)
(C++26 中移除)
template< class T >

void atomic_store_explicit
    ( std::shared_ptr<T>* p, std::shared_ptr<T> r,

      std::memory_order mo );
(5) (C++11 起)
(C++20 中弃用)
(C++26 中移除)
template< class T >

std::shared_ptr<T> atomic_exchange

    ( std::shared_ptr<T>* p, std::shared_ptr<T> r );
(6) (C++11 起)
(C++20 中弃用)
(C++26 中移除)
template< class T >

std::shared_ptr<T> atomic_exchange_explicit
    ( std::shared_ptr<T>* p, std::shared_ptr<T> r,

      std::memory_order mo );
(7) (C++11 起)
(C++20 中弃用)
(C++26 中移除)
template< class T >

bool atomic_compare_exchange_weak
    ( std::shared_ptr<T>* p, std::shared_ptr<T>* expected,

      std::shared_ptr<T> desired );
(8) (C++11 起)
(C++20 中弃用)
(C++26 中移除)
template< class T >

bool atomic_compare_exchange_strong
    ( std::shared_ptr<T>* p, std::shared_ptr<T>* expected,

      std::shared_ptr<T> desired );
(9) (C++11 起)
(C++20 中弃用)
(C++26 中移除)
template< class T >

bool atomic_compare_exchange_strong_explicit
    ( std::shared_ptr<T>* p, std::shared_ptr<T>* expected,
      std::shared_ptr<T> desired,

      std::memory_order success, std::memory_order failure );
(10) (C++11 起)
(C++20 中弃用)
(C++26 中移除)
template< class T >

bool atomic_compare_exchange_weak_explicit
    ( std::shared_ptr<T>* p, std::shared_ptr<T>* expected,
      std::shared_ptr<T> desired,

      std::memory_order success, std::memory_order failure );
(11) (C++11 起)
(C++20 中弃用)
(C++26 中移除)

如果多个执行线程无同步地访问同一 std::shared_ptr 对象,而其中由任何访问使用了 shared_ptr 的非 const 成员函数,那么就会发生数据竞争,除非所有这种访问都通过这些作为对应原子访问函数(std::atomic_loadstd::atomic_store 等)重载的函数进行。

注意 shared_ptr 的控制块是线程安全的:多个线程能同时用可改操作访问不同的 std::shared_ptr 对象,如 operator=reset,即使这些实例都是副本,并内部共享同一控制块也是如此。

1) 确定到 p 指向的共享指针的原子访问是否无锁。
2) 等价于 atomic_load_explicit(p, std::memory_order_seq_cst)
3) 返回 p 指向的共享指针。
与未特化的 std::atomic_load_explicit 相同,如果 mostd::memory_order_releasestd::memory_order_acq_rel,那么行为未定义。
4) 等价于 atomic_store_explicit(p, r, std::memory_order_seq_cst)
5) 将共享指针 r 原子地存储到 p 指向的共享指针,等价于 p->swap(r)
与未特化的 std::atomic_load_explicit 相同,如果 mostd::memory_order_releasestd::memory_order_acq_rel,那么行为未定义。
6) 等价于 atomic_exchange_explicit(p, r, std::memory_order_seq_cst)
7) 将共享指针 r 原子地存储到 p 指向的共享指针,并返回 p 先前指向的值。等价于 p->swap(r) 并返回交换后 r 的副本。
8) 等价于
atomic_compare_exchange_weak_explicit
    (p, expected, desired, std::memory_order_seq_cst,
                           std::memory_order_seq_cst)
9) 等价于
atomic_compare_exchange_strong_explicit
    (p, expected, desired, std::memory_order_seq_cst,
                           std::memory_order_seq_cst)
10,11) 比较 pexpected 指向的共享指针。
  • 如果它们等价(存储同一指针值,共享同一对象的所有权或均为空),那么用 success 指定的内存定序制约将 desired 赋给 *p 并返回 true
  • 如果它们不等价,那么用 failure 指定的内存定序制约将 *p 赋给 *expected 并返回 false
atomic_compare_exchange_weak_explicit 可能会虚假地失败。
如果 exptected 是空指针,或者 failurestd::memory_order_releasestd::memory_order_acq_rel,那么行为未定义。

如果 p 是空指针,那么这些函数的行为均未定义。

参数

p, expected - 指向 std::shared_ptr 的指针
r, desired - 一个 std::shared_ptr
mo, success, failure - std::memory_order 类型的内存定序选择符

异常

这些函数不会抛出异常。

返回值

1) 在原子访问使用无锁指令时返回 true
2,3) 被指向的共享指针的副本。
4,5) (无)
6,7) 先前被指向的共享指针的副本
8-11) 在共享指针等价并进行了交换时返回 true,否则返回 false

注解

这些函数典型地利用互斥体实现,互斥体存储于一个全局散列表中,其中以指针值为键。

并发 TS 提供原子智能指针类 atomic_shared_ptratomic_weak_ptr 作为使用这些函数的替代品。

这些函数被弃用,取代者是 std::atomic 模板的特化:std::atomic<std::shared_ptr>std::atomic<std::weak_ptr>

(C++20 起)
(C++26 前)

这些函数被删除,取代者是 std::atomic 模板的特化:std::atomic<std::shared_ptr>std::atomic<std::weak_ptr>

(C++26 起)

示例

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 2980 C++11 空的 shared_ptr 决不等价 在它们存储同一指针值的情况下等价

参阅

检查该原子类型的操作是否是免锁的
(函数模板)
原子地以非原子实参替换原子对象的值
(函数模板)
原子地获得存储于原子对象的值
(函数模板)
原子地以非原子实参的值替换原子对象的值,并返回该原子对象的旧值
(函数模板)
原子地比较原子对象和非原子实参的值,相等时进行原子交换,不相等时进行原子加载
(函数模板)