- atomic[meta header]
- std[meta namespace]
- atomic_ref[meta class]
- function[meta id-type]
- cpp20[meta cpp]
T fetch_and(T operand, memory_order order = memory_order_seq_cst) const noexcept;- memory_order[link /reference/atomic/memory_order.md]
- memory_order_seq_cst[link /reference/atomic/memory_order.md]
AND演算を行う
std::atomic_ref<T*>の場合、型Tがオブジェクト型であること。型Tがvoid*や関数ポインタであってはならない (C++17)
orderで指定されたメモリオーダーにしたがって、現在の値にoperandをANDした値でアトミックに置き換える
変更前の値が返される
投げない
- この関数は、
atomic_refクラスの整数型に対する特殊化で定義される - 符号付き整数型に対しては、符号なし整数型に変換されたかのようにしたあと演算が行われ、結果は符号付き整数型になる。未定義動作はない
#include <iostream>
#include <atomic>
#include <bitset>
int main()
{
int value = 0b1011;
std::atomic_ref<int> x{value};
x.fetch_and(0b1110);
std::cout << std::bitset<4>(value).to_string() << std::endl;
}- fetch_and[color ff0000]
- to_string()[link /reference/bitset/bitset/to_string.md]
1010
#include <iostream>
#include <atomic>
#include <thread>
#include <bitset>
int main()
{
int value = 0b1111;
// 複数スレッドでビット複合演算を呼んでも、
// 最終的に全てのスレッドでのビット複合演算が処理された値になる
std::thread t1 {[&value] {
std::atomic_ref{value}.fetch_and(0b0111);
}};
std::thread t2 {[&value] {
std::atomic_ref{value}.fetch_and(0b0101);
}};
t1.join();
t2.join();
std::cout << std::bitset<4>(value).to_string() << std::endl;
}- fetch_and[color ff0000]
- to_string()[link /reference/bitset/bitset/to_string.md]
0101
- C++20
- Clang: (9.0時点で実装なし)
- GCC: 10.1
- Visual C++: ??