Atomically replaces the value pointed by obj with the result of bitwise XOR between the old value of obj and arg. Returns the value obj held previously.
The operation is performed as if the following is executed:
1,2) obj->fetch_xor(arg)
3,4) obj->fetch_xor(arg, order)
If std::atomic<T>
has no fetch_xor
member (this member is only provided for integral types except bool), the program is ill-formed.
The value immediately preceding the effects of this function in the modification order of *obj.
[edit] Example [edit] Defect reportsThe 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 deduced
std::atomic<T>
) [edit] replaces the atomic object with the result of bitwise OR with a non-atomic argument and obtains the previous value of the atomic
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4