命名空间
变体
动作

std::atomic_store, std::atomic_store_explicit

来自 cppreference.com
< cpp‎ | atomic
 
 
并发支持库
线程
(C++11)
(C++20)
this_thread 命名空间
(C++11)
(C++11)
(C++11)
协作取消
互斥
通用锁管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
条件变量
(C++11)
信号量
闩锁和屏障
(C++20)
(C++20)
期货
(C++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
危险指针
原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中已弃用)
(C++11)(C++20 中已弃用)
内存排序
原子操作的自由函数
atomic_storeatomic_store_explicit
(C++11)(C++11)
原子标志的自由函数
 
定义在头文件 <atomic>
template< class T >

void atomic_store( std::atomic<T>* obj,

                   typename std::atomic<T>::value_type desired ) noexcept;
(1) (自 C++11 起)
template< class T >

void atomic_store( volatile std::atomic<T>* obj,

                   typename std::atomic<T>::value_type desired ) noexcept;
(2) (自 C++11 起)
template< class T >

void atomic_store_explicit( std::atomic<T>* obj,
                            typename std::atomic<T>::value_type desired,

                            std::memory_order order) noexcept;
(3) (自 C++11 起)
template< class T >

void atomic_store_explicit( volatile std::atomic<T>* obj,
                            typename std::atomic<T>::value_type desired,

                            std::memory_order order) noexcept;
(4) (自 C++11 起)
1,2) 原子地将 obj 指向的原子对象的值替换为 desired 的值,就像通过 obj->store(desired) 一样。
3,4) 原子地将 obj 指向的原子对象的值替换为 desired 的值,就像通过 obj->store(desired, order) 一样。
如果 orderstd::memory_order_consumestd::memory_order_acquirestd::memory_order_acq_rel 之一,则行为未定义。

内容

[编辑] 参数

obj - 指向要修改的原子对象的指针
desired - 要存储在原子对象中的值
order - 内存同步排序

[编辑] 返回值

(无)

[编辑] 缺陷报告

以下行为更改缺陷报告被追溯应用于以前发布的 C++ 标准。

DR 应用于 已发布的行为 正确行为
P0558R1 C++11 需要完全类型匹配,因为
T 是从多个参数推断的
T 仅从 obj 推断

[编辑] 另请参见

原子地将原子对象的值替换为非原子参数
(std::atomic<T> 的公有成员函数) [编辑]
原子地获取存储在原子对象中的值
(函数模板) [编辑]
为给定的原子操作定义内存排序约束
(枚举) [编辑]
std::shared_ptr 特化原子操作
(函数模板)
C 文档 适用于 atomic_store, atomic_store_explicit