atomic_fetch_sub, atomic_fetch_sub_explicit
來自 cppreference.com
在標頭檔案 <stdatomic.h> 中定義 |
||
C atomic_fetch_sub( volatile A* obj, M arg ); |
(1) | (C11 起) |
C atomic_fetch_sub_explicit( volatile A* obj, M arg, memory_order order ); |
(2) | (C11 起) |
原子地將 obj
指向的值替換為 obj
舊值減去 arg
的結果,並返回 obj
先前持有的值。該操作是讀-修改-寫操作。第一個版本根據 memory_order_seq_cst 安排記憶體訪問順序,第二個版本根據 order
安排記憶體訪問順序。
這是一個為所有原子物件型別 A
定義的泛型函式。引數是指向 volatile 原子型別的指標,以接受非 volatile 和volatile(例如記憶體對映 I/O)原子物件的地址,並且在對 volatile 原子物件應用此操作時保留 volatile 語義。如果 A
是原子整數型別,則 M
是與 A
對應的非原子型別;如果 A
是原子指標型別,則 M
是 ptrdiff_t。
泛型函式的名稱是宏還是具有外部連結的識別符號是未指定的。如果抑制宏定義以訪問實際函式(例如用括號括起來,如 (atomic_fetch_sub)(...)),或者程式定義了一個與泛型函式同名的外部識別符號,則行為是未定義的。
對於有符號整數型別,算術運算定義為使用二進位制補碼錶示。沒有未定義的結果。對於指標型別,結果可能是一個未定義的地址,但操作本身沒有未定義行為。
目錄 |
[編輯] 引數
obj | - | 指向要修改的原子物件的指標 |
arg | - | 要從原子物件中儲存的值中減去的值 |
順序 | - | 此操作的記憶體同步順序:允許所有值 |
[編輯] 返回值
obj
指向的原子物件先前持有的值。
[編輯] 參考
- C17 標準 (ISO/IEC 9899:2018)
- 7.17.7.5 原子獲取和修改泛型函式 (p: 208)
- C11 標準 (ISO/IEC 9899:2011)
- 7.17.7.5 原子獲取和修改泛型函式 (p: 284-285)
[編輯] 另請參閱
原子加法 (函式) | |
C++ 文件 用於 atomic_fetch_sub, atomic_fetch_sub_explicit
|