名稱空間
變體
操作

atomic_compare_exchange_weak, atomic_compare_exchange_strong, atomic_compare_exchange_weak_explicit, atomic_compare_exchange_strong_explicit

來自 cppreference.com
< c‎ | atomic
在標頭檔案 <stdatomic.h> 中定義
_Bool atomic_compare_exchange_strong( volatile A* obj,
                                      C* expected, C desired );
(1) (C11 起)
_Bool atomic_compare_exchange_weak( volatile A *obj,
                                    C* expected, C desired );
(2) (C11 起)
_Bool atomic_compare_exchange_strong_explicit( volatile A* obj,

                                               C* expected, C desired,
                                               memory_order succ,

                                               memory_order fail );
(3) (C11 起)
_Bool atomic_compare_exchange_weak_explicit( volatile A *obj,

                                             C* expected, C desired,
                                             memory_order succ,

                                             memory_order fail );
(4) (C11 起)

原子性地比較 obj 所指向記憶體的內容與 expected 所指向記憶體的內容,如果它們在位模式上相等,則將前者替換為 desired(執行讀-修改-寫操作)。否則,將 obj 所指向記憶體的實際內容載入到 *expected 中(執行載入操作)。

讀-修改-寫和載入操作的記憶體模型分別為 succfail。(1-2) 版本預設使用 memory_order_seq_cst

函式的弱形式((2) 和 (4))允許發生偽故障,即即使它們相等,也表現得像 *obj != *expected。當比較並交換在迴圈中時,弱版本在某些平臺上會產生更好的效能。當弱比較並交換需要迴圈而強比較並交換不需要時,強比較並交換是首選。

這是一個針對所有 原子物件型別 A 定義的泛型函式。引數是指向 volatile 原子型別的指標,以接受非 volatile 和 volatile(例如記憶體對映 I/O)原子物件的地址,並且當對此 volatile 原子物件執行此操作時,volatile 語義得以保留。C 是對應於 A 的非原子型別。

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

目錄

[編輯] 引數

obj - 指向要測試和修改的原子物件的指標
expected - 指向期望在原子物件中找到的值的指標
desired - 如果原子物件符合預期,則儲存到原子物件中的值
succ - 如果比較成功,則為讀-修改-寫操作的記憶體同步順序。允許所有值。
fail - 如果比較失敗,則為載入操作的記憶體同步順序。不能是 memory_order_releasememory_order_acq_rel,也不能指定比 succ 更強的順序

[編輯] 返回值

比較的結果:如果 *obj 等於 *exp,則為 true,否則為 false

[編輯] 注意

atomic_compare_exchange_* 家族的行為如同原子性地執行了以下操作

if (memcmp(obj, expected, sizeof *obj) == 0) {
    memcpy(obj, &desired, sizeof *obj);
    return true;
} else {
    memcpy(expected, obj, sizeof *obj);
    return false;
}

[編輯] 參考

  • C17 標準 (ISO/IEC 9899:2018)
  • 7.17.7.4 atomic_compare_exchange 泛型函式 (p: 207)
  • C11 標準 (ISO/IEC 9899:2011)
  • 7.17.7.4 atomic_compare_exchange 泛型函式 (p: 283-284)

[編輯] 另請參閱

與原子物件的值交換
(function) [編輯]
C++ 文件 for atomic_compare_exchange_weak, atomic_compare_exchange_strong, atomic_compare_exchange_weak_explicit, atomic_compare_exchange_strong_explicit