std::atomic_load, std::atomic_load_explicit
来自cppreference.com
| 定义于头文件 <atomic>
|
||
| (1) | (C++11 起) | |
| template< class T > T atomic_load( const std::atomic<T>* obj ) noexcept; |
||
| template< class T > T atomic_load( const volatile std::atomic<T>* obj ) noexcept; |
||
| (2) | (C++11 起) | |
| template< class T > T atomic_load_explicit( const std::atomic<T>* obj, |
||
| template< class T > T atomic_load_explicit( const volatile std::atomic<T>* obj, |
||
1) 如同用 obj->load() 原子地获得
obj 所指向的值。2) 如同用 obj->load(order) 原子地获得
obj 所指向的值。参数
| obj | - | 指向要加载的原子对象的指针 |
| order | - | 此操作所用的内存同步顺序:只容许 std::memory_order_relaxed 、 std::memory_order_consume 、 std::memory_order_acquire 和 std::memory_order_seq_cst 。 |
返回值
obj 所指向的原子对象所保有的值。
参阅
| 原子地获得原子对象的值 ( std::atomic<T> 的公开成员函数) | |
| (C++11)(C++11) |
原子地以非原子实参替换原子对象的值 (函数模板) |
| (C++11) |
为给定的原子操作定义内存顺序制约 (枚举) |
| 为 std::shared_ptr 特化原子操作 (函数模板) |