命名空间
变体
操作

std::atomic_store,std::atomic_store_explicit

来自 cppreference.cn
< 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++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 中弃用)
内存排序
(C++11)(在 C++26 中弃用)
原子操作的自由函数
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 之一,则行为未定义。

目录

[edit] 参数

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

[edit] 返回值

(无)

[edit] 缺陷报告

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

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

[edit] 参见

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