std::atomic_store, std::atomic_store_explicit
來自 cppreference.com
定義於標頭檔案 <atomic> |
||
template< class T > void atomic_store( std::atomic<T>* obj, |
(1) | (C++11 起) |
template< class T > void atomic_store( volatile std::atomic<T>* obj, |
(2) | (C++11 起) |
template< class T > void atomic_store_explicit( std::atomic<T>* obj, |
(3) | (C++11 起) |
template< class T > void atomic_store_explicit( volatile std::atomic<T>* obj, |
(4) | (C++11 起) |
1,2) 原子地將 obj 指向的值替換為 desired 的值,如同透過 obj->store(desired)。
3,4) 原子地將 obj 指向的值替換為 desired 的值,如同透過 obj->store(desired, order)。
如果 order 是 std::memory_order_consume、std::memory_order_acquire 和 std::memory_order_acq_rel 之一,則行為未定義。
目錄 |
[編輯] 引數
obj | - | 指向要修改的原子物件的指標 |
desired | - | 要儲存到原子物件中的值 |
順序 | - | 記憶體同步順序 |
[編輯] 返回值
(無)
[編輯] 缺陷報告
下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
P0558R1 | C++11 | 因為要求精確型別匹配T 是從多個引數推匯出來的 |
T 僅從obj 中推導 |
[編輯] 參閱
原子地將原子物件的值替換為非原子引數 ( std::atomic<T> 的公共成員函式) | |
(C++11)(C++11) |
原子地獲取原子物件中儲存的值 (函式模板) |
(C++11) |
定義給定原子操作的記憶體排序約束 (列舉) |
(C++20 中已棄用)(C++26 中移除) |
為 std::shared_ptr 特化原子操作 (函式模板) |
C 文件 用於 atomic_store, atomic_store_explicit
|