std::atomic_fetch_and,std::atomic_fetch_and_explicit (3) - Linux Manuals
std::atomic_fetch_and,std::atomic_fetch_and_explicit: std::atomic_fetch_and,std::atomic_fetch_and_explicit
NAME
std::atomic_fetch_and,std::atomic_fetch_and_explicit - std::atomic_fetch_and,std::atomic_fetch_and_explicit
Synopsis
Defined in header <atomic>
template< class T >
T atomic_fetch_and( std::atomic<T>* obj,
typename std::atomic<T>::value_type arg ) noexcept;
template< class T >
T atomic_fetch_and( volatile std::atomic<T>* obj,
typename std::atomic<T>::value_type arg ) noexcept;
template< class T > (1) (since C++11)
T atomic_fetch_and_explicit( std::atomic<T>* obj,
typename std::atomic<T>::value_type arg,
std::memory_order order) noexcept; (2) (since C++11)
template< class T >
T atomic_fetch_and_explicit( volatile std::atomic<T>* obj,
typename std::atomic<T>::value_type arg,
std::memory_order order) noexcept;
Atomically replaces the value pointed by obj with the result of bitwise AND 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) obj->fetch_and(arg)
2) obj->fetch_and(arg, order)
If std::atomic<T> has no fetch_and member (this member is only provided for integral_types), the program is ill-formed.
Parameters
obj - pointer to the atomic object to modify. bool is not an Integral type for the purposes of the atomic operations.
arg - the value to bitwise AND to the value stored in the atomic object
order - the memory synchronization ordering for this operation: all values are permitted.
Return value
The value immediately preceding the effects of this function in the modification_order of *obj.
Possible implementation
Example
// Run this code