• Class / Function / Type

      std::
    • Header file

      <>
    • Other / All

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

    履歴 編集

    function template
    <atomic>

    std::atomic_exchange_explicit

    namespace std {
      template <class T>
      T
        atomic_exchange_explicit(
          volatile atomic<T>* object,
          T desired,
          memory_order order) noexcept;           // (1) C++11
      template <class T>
      T
        atomic_exchange_explicit(
          volatile atomic<T>* object,
          typename atomic<T>::value_type desired,
          memory_order order) noexcept;           // (1) C++17
    
      template <class T>
      T
        atomic_exchange_explicit(
          atomic<T>* object,
          T desired,
          memory_order order) noexcept;           // (2) C++11
      template <class T>
      T
        atomic_exchange_explicit(
          atomic<T>* object,
          typename atomic<T>::value_type desired,
          memory_order order) noexcept;           // (2) C++17
      template <class T>
      constexpr T
        atomic_exchange_explicit(
          atomic<T>* object,
          typename atomic<T>::value_type desired,
          memory_order order) noexcept;           // (2) C++26
    ]
    

    概要

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

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

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

    効果

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

    戻り値

    変更前の値が返される

    例外

    投げない

    備考

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

    #include <iostream>
    #include <atomic>
    
    int main()
    {
      std::atomic<int> x(1);
    
      if (std::atomic_exchange_explicit(&x, 2, std::memory_order_acquire) == 1) {
        std::cout << "replaced 1 by 2" << std::endl;
      }
      else {
        std::cout << "replace failed" << std::endl;
      }
    }
    

    出力

    replaced 1 by 2
    

    バージョン

    言語

    • C++11

    処理系

    関連項目

    参照