- atomic[meta header]
- std[meta namespace]
- function template[meta id-type]
- cpp11[meta cpp]
namespace std {
template <class T>
T atomic_fetch_and(
volatile atomic<T>* object,
T operand) noexcept; // (1) C++11
template <class T>
T atomic_fetch_and(
volatile atomic<T>* object,
typename atomic<T>::value_type operand) noexcept; // (1) C++17
template <class T>
T atomic_fetch_and(
atomic<T>* object,
T operand) noexcept; // (2) C++11
template <class T>
T atomic_fetch_and(
atomic<T>* object,
typename atomic<T>::value_type operand) noexcept; // (2) C++11
}
- atomic[link atomic.md]
アトミックにAND演算を行う
- (1), (2) :
- C++17 : 型
T
がオブジェクト型であること。型T
がvoid*
や関数ポインタであってはならない
- C++17 : 型
- (1) :
- C++20 :
atomic<T>::is_always_lock_free
がtrue
であること
- C++20 :
memory_order_seq_cst
のメモリオーダーにしたがって、現在の値にoperand
をANDした値でアトミックに置き換える
変更前の値が返される
投げない
符号付き整数型に対しては、2の補数表現による演算が行われ、未定義動作はない。アドレス型に関しては結果として未定義アドレスになる場合があるが、それ以外の未定義動作はない。
#include <iostream>
#include <atomic>
#include <bitset>
int main()
{
int a = 0x0b;
int b = 0x0e;
std::atomic<int> x(a);
std::atomic_fetch_and(&x, b);
std::cout << std::bitset<4>(a).to_string() << std::endl;
std::cout << std::bitset<4>(b).to_string() << std::endl;
std::cout << std::bitset<4>(x.load()).to_string() << std::endl;
}
- std::atomic_fetch_and[color ff0000]
- x.load()[link /reference/atomic/atomic/load.md]
- to_string()[link /reference/bitset/bitset/to_string.md]
1011
1110
1010
- C++11
- Clang: ??
- GCC: 4.7.0
- ICC: ??
- Visual C++: 2012, 2013
- P0558R1 Resolving
atomic<T>
named base class inconsistencies - P1831R1 Deprecating
volatile
: library- C++20での、
volatile
版への制約追加
- C++20での、