std::atomic<T>::fetch_xor

来自cppreference.com
< cpp‎ | atomic‎ | atomic
 
 
并发支持库
线程
(C++11)
(C++20)
(C++20)
this_thread 命名空间
(C++11)
(C++11)
(C++11)
互斥
(C++11)
(C++11)  
通用锁管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
条件变量
(C++11)
信号量
闩与屏障
(C++20)
(C++20)
未来体
(C++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
(C++26)
风险指针





原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中弃用)
(C++11)(C++20 中弃用)
内存定序
原子操作的自由函数
原子标志的自由函数
 
 
atomic<整数类型 > 特化才有的成员
T fetch_xor( T arg, std::memory_order order =
                        std::memory_order_seq_cst ) noexcept;
(1) (C++11 起)
T fetch_xor( T arg, std::memory_order order =
                        std::memory_order_seq_cst ) volatile noexcept;
(2) (C++11 起)

以当前值和 arg 逐位异或的结果原子地替换当前值。运算是读-修改-写操作。按照 order 的值影响内存。

重载 (2) 在参与重载决议且 std::atomic<T>::is_always_lock_freefalse 时被弃用。

(C++20 起)

参数

arg - 逐位异或的另一实参
order - 强制的内存定序约束

返回值

*this修改顺序中,紧接此函数生效之前的值。

参阅

将原子对象替换为与非原子实参逐位异或的结果,并获得原子对象的先前值
(函数模板)