Skip to content

Latest commit

 

History

History
100 lines (73 loc) · 2.36 KB

atomic_fetch_sub_explicit.md

File metadata and controls

100 lines (73 loc) · 2.36 KB

atomic_fetch_sub_explicit

  • atomic[meta header]
  • std[meta namespace]
  • function template[meta id-type]
  • cpp11[meta cpp]
namespace std {
  template <class T>
  T atomic_fetch_sub_explicit(
      volatile atomic<T>* object,
      T operand,
      memory_order order) noexcept;                // (1) C++11

  template <class T>
  T atomic_fetch_sub_explicit(
      volatile atomic<T>* object,
      typename atomic<T>::difference_type operand,
      memory_order order) noexcept;                // (1) C++17

  template <class T>
  T atomic_fetch_sub_explicit(
      atomic<T>* object,
      T operand,
      memory_order order) noexcept;                // (2) C++11

  template <class T>
  T atomic_fetch_sub_explicit(
      atomic<T>* object,
      typename atomic<T>::difference_type operand,
      memory_order order) noexcept;                // (2) C++17
}
  • atomic[link atomic.md]
  • memory_order[link memory_order.md]

概要

アトミックに減算を行う

要件

  • C++17 : 型Tがオブジェクト型であること。型Tvoid*や関数ポインタであってはならない

効果

orderで指定されたメモリオーダーにしたがって、現在の値にoperandを減算した値でアトミックに置き換える

戻り値

変更前の値が返される

例外

投げない

備考

符号付き整数型に対しては、2の補数表現による演算が行われ、未定義動作はない。アドレス型に関しては結果として未定義アドレスになる場合があるが、それ以外の未定義動作はない。

#include <iostream>
#include <atomic>

int main()
{
  std::atomic<int> x(3);

  int before = std::atomic_fetch_sub_explicit(&x, 2, std::memory_order_seq_cst);

  std::cout << before << std::endl;
  std::cout << x.load() << std::endl;
}
  • std::atomic_fetch_sub_explicit[color ff0000]
  • x.load()[link /reference/atomic/atomic/load.md]

出力

3
1

バージョン

言語

  • C++11

処理系

参照