|
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Defined in header <atomic> | ||
template<class T> T atomic_fetch_xor(std::atomic<T>* obj, | (1) | (since C++11) |
template<class T> T atomic_fetch_xor(volatilestd::atomic<T>* obj, | (2) | (since C++11) |
template<class T> T atomic_fetch_xor_explicit(std::atomic<T>* obj, | (3) | (since C++11) |
template<class T> T atomic_fetch_xor_explicit(volatilestd::atomic<T>* obj, | (4) | (since C++11) |
Atomically replaces the value pointed byobj with the result of bitwise XOR between the old value ofobj andarg. Returns the valueobj held previously.
The operation is performed as if the following is executed:
Ifstd::atomic<T> has nofetch_xor member (this member is only provided forintegral types exceptbool), the program is ill-formed.
Contents |
| obj | - | pointer to the atomic object to modify |
| arg | - | the value to bitwise XOR to the value stored in the atomic object |
| order | - | the memory synchronization ordering |
The value immediately preceding the effects of this function in themodification order of*obj.
| This section is incomplete Reason: no example |
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| P0558R1 | C++11 | exact type match was required becauseT was deduced from multiple arguments | T is only deducedfromobj |
| atomically performs bitwise XOR between the argument and the value of the atomic object and obtains the value held previously (public member function of std::atomic<T>)[edit] | |
(C++11)(C++11) | replaces the atomic object with the result of bitwise OR with a non-atomic argument and obtains the previous value of the atomic (function template)[edit] |
(C++11)(C++11) | replaces the atomic object with the result of bitwise AND with a non-atomic argument and obtains the previous value of the atomic (function template)[edit] |
C documentation foratomic_fetch_xor,atomic_fetch_xor_explicit | |