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
処理系
- Clang: ??
- GCC: 4.7.0 ✅
- ICC: ??
- Visual C++: 2012 ✅