Namespaces
Variants
Views
Actions

Difference between revisions of "cpp/atomic/atomic fetch and"

From cppreference.com
< cpp‎ | atomic
(+)
 
m (copypaste typo)
Line 21: Line 21:
 
{{ddcl list end}}
 
{{ddcl list end}}
  
1-2) Atomically replaces the value pointed by {{tt|arg}} with the result of bitwise AND between the old value of {{tt|obj}} and {{tt|arg}}, and returns the value {{tt|obj}} held previously, as if by {{cpp|obj->fetch_and(desr)}}
+
1-2) Atomically replaces the value pointed by {{tt|arg}} with the result of bitwise AND between the old value of {{tt|obj}} and {{tt|arg}}, and returns the value {{tt|obj}} held previously, as if by {{cpp|obj->fetch_and(arg)}}
  
3-4) Atomically replaces the value pointed by {{tt|arg}} with the result of bitwise AND between the old value of {{tt|obj}} and {{tt|arg}}, and returns the value {{tt|obj}} held previously, as if by {{cpp|obj->fetch_and(desr, order)}}
+
3-4) Atomically replaces the value pointed by {{tt|arg}} with the result of bitwise AND between the old value of {{tt|obj}} and {{tt|arg}}, and returns the value {{tt|obj}} held previously, as if by {{cpp|obj->fetch_and(arg, order)}}
 
===Parameters===
 
===Parameters===
  

Revision as of 12:58, 5 January 2012

Template:cpp/atomic/sidebar Template:ddcl list begin <tr class="t-dsc-header">

<td>
Defined in header <atomic>
</td>

<td></td> <td></td> </tr> <tr class="t-dcl ">

<td >
template< class Integral >
Integral atomic_fetch_and( std::atomic<Integral>* obj, Integral arg );
</td>

<td > (1) </td> <td > (since C++11) </td> </tr> <tr class="t-dcl ">

<td >
template< class Integral >
Integral atomic_fetch_and( volatile std::atomic<Integral>* obj, Integral arg );
</td>

<td > (2) </td> <td > (since C++11) </td> </tr> <tr class="t-dcl ">

<td >
template< class Integral >
Integral atomic_fetch_and_explicit( std::atomic<Integral>* obj, Integral arg, std::memory_order order);
</td>

<td > (3) </td> <td > (since C++11) </td> </tr> <tr class="t-dcl ">

<td >
template< class Integral >
Integral atomic_fetch_and_explicit( volatile std::atomic<Integral>* obj, Integral arg, std::memory_order order);
</td>

<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 Template:cpp

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 Template:cpp

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

noexcept specification:  
noexcept
  

Equivalent definition

Template:eq fun cpp

Example

Template:example cpp

See also

Template:cpp/atomic/atomic/dcl list fetch andTemplate:cpp/atomic/dcl list atomic fetch orTemplate:cpp/atomic/dcl list atomic fetch xor