最終更新日時(UTC):
が更新

履歴 編集

function template
<atomic>

std::atomic_exchange(C++11)

namespace std {
  template <class T>
  T atomic_exchange(
      volatile atomic<T>* object,
      T desired) noexcept;                              // (1) C++11

  template <class T>
  T atomic_exchange(
      volatile atomic<T>* object,
      typename atomic<T>::value_type desired) noexcept; // (1) C++17

  template <class T>
  T atomic_exchange(
      atomic<T>* object,
      T desired) noexcept;                              // (2) C++11

  template <class T>
  T atomic_exchange(
      atomic<T>* object,
      typename atomic<T>::value_type desired) noexcept; // (2) C++17
}

概要

アトミックに値を入れ替える

テンプレートパラメータ制約

  • (1) :
    • C++20 : atomic<T>::is_always_lock_freetrueであること

効果

memory_order_seq_cstのメモリオーダーにしたがって、現在の値をdesiredでアトミックに置き換える

戻り値

変更前の値が返される

例外

投げない

備考

この関数は、特殊化されたatomic型に対して定義される。

#include <iostream>
#include <atomic>

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

  if (std::atomic_exchange(&x, 2) == 1) {
    std::cout << "replaced 1 by 2" << std::endl;
  }
  else {
    std::cout << "replace failed" << std::endl;
  }
}

出力

replaced 1 by 2

バージョン

言語

  • C++11

処理系

関連項目

参照