名稱空間
變體
操作

atomic_fetch_xor, atomic_fetch_xor_explicit

來自 cppreference.com
< c‎ | atomic
在標頭檔案 <stdatomic.h> 中定義
C atomic_fetch_xor( volatile A* obj, M arg );
(1) (C11 起)
C atomic_fetch_xor_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 是原子指標型別,則 Mptrdiff_t

泛型函式的名稱是宏還是具有外部連結宣告的識別符號是未指定的。如果宏定義被抑制以訪問實際函式(例如用括號括起來,如 (atomic_fetch_xor)(...)),或者程式定義了一個具有泛型函式名稱的外部識別符號,則行為是未定義的。

目錄

[編輯] 引數

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_xor, atomic_fetch_xor_explicit