Skip to content

Latest commit

 

History

History
88 lines (69 loc) · 2.87 KB

future_error.md

File metadata and controls

88 lines (69 loc) · 2.87 KB

future_error

  • future[meta header]
  • std[meta namespace]
  • class[meta id-type]
  • cpp11[meta cpp]
namespace std {
  class future_error : public logic_error;
}
  • logic_error[link /reference/stdexcept.md]

概要

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();
}
  • std::future_error[color ff0000]
  • std::promise[link promise.md]
  • p.set_value[link promise/set_value.md]
  • p.get_future()[link promise/get_future.md]
  • std::future[link future.md]
  • f.get()[link future/get.md]
  • std::move[link /reference/utility/move.md]

出力例

3
value:3
what:Promise already satisfied

バージョン

言語

  • C++11

処理系

参照