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

履歴 編集

class
<future>

std::future_error(C++11)

namespace std {
  class future_error : public logic_error;
}

概要

future_errorは、future/promise操作でのエラーを扱うための例外クラスである。

メンバ関数

名前 説明 対応バージョン
future_error(error_code ec); error_codeオブジェクトからfuture_errorオブジェクトを生成する。
注:このクラスは標準ライブラリの内部で送出される例外クラスで、ユーザーが使用するものではないため、コンストラクタは説明のためにのみ記載されている。
C++11
C++14まで
future_error(future_errc e); future_errcオブジェクトからfuture_errorオブジェクトを生成する。
包含しているerror_codeオブジェクトをmake_error_code(e)から初期化する。
C++17
const error_code& code() const noexcept; 包含しているerror_codeオブジェクトへの参照を取得する C++11
virtual const char* what() const noexcept; エラー理由となる実装依存文字列(code.message())を返す C++11

#include <iostream>
#include <future>
#include <thread>
#include <utility>

void foo(std::promise<int> p)
{
  p.set_value(3);

  try {
    p.set_value(1); // promiseに2回以上書き込むとエラー
  }
  catch (std::future_error& e) {
    std::cout << "value:" << e.code().value() << std::endl;
    std::cout << "what:" << e.what() << std::endl;
  }
}

int main()
{
  std::promise<int> p;
  std::future<int> f = p.get_future();

  std::thread t(foo, std::move(p));

  std::cout << f.get() << std::endl;

  t.join();
}

出力例

3
value:3
what:Promise already satisfied

バージョン

言語

  • C++11

処理系

参照