|
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||
(C++20) | ||||
(C++20) | ||||
(C++20) | ||||
| Constants | ||||
(C++17) | ||||
| Specialized member functions | ||||
| Specialized for integral, floating-point(C++20) and pointer types | ||||
| Specialized for integral and pointer types only | ||||
(C++26) | ||||
(C++26) | ||||
| Specialized for integral types only | ||||
atomic::fetch_and | ||||
member only of atomic<Integral > specializations | ||
T fetch_and( T arg,std::memory_order order= std::memory_order_seq_cst)noexcept; | (1) | (since C++11) |
T fetch_and( T arg,std::memory_order order= std::memory_order_seq_cst)volatilenoexcept; | (2) | (since C++11) |
Atomically replaces the current value with the result of bitwise AND of the value andarg. The operation is read-modify-write operation. Memory is affected according to the value oforder.
It is deprecated ifstd::atomic<T>::is_always_lock_free isfalse and overload(2) participates in overload resolution. | (since C++20) |
| arg | - | the other argument of bitwise AND |
| order | - | memory order constraints to enforce |
The value immediately preceding the effects of this function in themodification order of*this.
(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] |