std::atomic_fetch_and, std::atomic_fetch_and_explicit
Template:ddcl list begin <tr class="t-dsc-header">
<td><atomic>
<td></td> <td></td> </tr> <tr class="t-dcl ">
<td >Integral atomic_fetch_and( std::atomic<Integral>* obj, Integral arg );
<td > (1) </td> <td > (since C++11) </td> </tr> <tr class="t-dcl ">
<td >Integral atomic_fetch_and( volatile std::atomic<Integral>* obj, Integral arg );
<td > (2) </td> <td > (since C++11) </td> </tr> <tr class="t-dcl ">
<td >Integral atomic_fetch_and_explicit( std::atomic<Integral>* obj, Integral arg,
<td > (3) </td> <td > (since C++11) </td> </tr> <tr class="t-dcl ">
<td >Integral atomic_fetch_and_explicit( volatile std::atomic<Integral>* obj, Integral arg,
<td > (4) </td> <td > (since C++11) </td> </tr> Template:ddcl list end
1-2) Atomically replaces the value pointed by arg
with the result of bitwise AND between the old value of obj
and arg
, and returns the value obj
held previously, as if by obj->fetch_and(arg)
3-4) Atomically replaces the value pointed by arg
with the result of bitwise AND between the old value of obj
and arg
, and returns the value obj
held previously, as if by obj->fetch_and(arg, order)
Contents |
Parameters
obj | - | pointer to the atomic object to modify |
arg | - | the value to bitwise AND to the value stored in the atomic object |
order | - | the memory sycnhronization ordering for this operation: all values are permitted. |
Return value
The value held previously by the atomic object pointed to by obj
Exceptions
Possible implementation
template< class T > typename std::enable_if<std::is_integral<T>::value && !std::is_same<T, bool>::value, T>::type atomic_fetch_and( std::atomic<T>* obj, T arg ); { return obj->fetch_and(arg); } |
Example
This section is incomplete Reason: no example |