atomic_load, atomic_load_explicit
來自 cppreference.com
在標頭檔案 <stdatomic.h> 中定義 |
||
C atomic_load( const volatile A* obj ); |
(1) | (C11 起) |
C atomic_load_explicit( const volatile A* obj, memory_order order ); |
(2) | (C11 起) |
原子地載入並返回由 obj
指向的原子變數的當前值。該操作是原子讀取操作。
第一個版本根據 memory_order_seq_cst 排序記憶體訪問,第二個版本根據 order
排序記憶體訪問。order
必須是 memory_order_relaxed、memory_order_consume、memory_order_acquire 或 memory_order_seq_cst 之一。否則行為未定義。
這是一個為所有原子物件型別 A
定義的泛型函式。引數是指向 volatile 原子型別的指標,以接受非 volatile 和volatile(例如記憶體對映 I/O)原子物件的地址,並且當將此操作應用於 volatile 原子物件時,volatile 語義得以保留。C
是與 A
對應的非原子型別。
泛型函式的名稱是宏還是具有外部連結的識別符號未指定。如果為了訪問實際函式而抑制宏定義(例如用括號括起來,如 (atomic_load)(...)),或者程式定義了一個具有泛型函式名稱的外部識別符號,則行為未定義。
目錄 |
[編輯] 引數
obj | - | 指向要訪問的原子物件的指標 |
順序 | - | 此操作的記憶體同步順序 |
[編輯] 返回值
由 obj
指向的原子變數的當前值。
[編輯] 參考
- C17 標準 (ISO/IEC 9899:2018)
- 7.17.7.2 atomic_load 泛型函式 (p: 206)
- C11 標準 (ISO/IEC 9899:2011)
- 7.17.7.2 atomic_load 泛型函式 (p: 282)
[編輯] 另請參閱
在原子物件中儲存值 (函式) | |
C++ 文件 for atomic_load, atomic_load_explicit
|