- future[meta header]
- std[meta namespace]
- class template[meta id-type]
- cpp11[meta cpp]
namespace std {
template <class R>
class future;
}
future
は、「別スレッドでの処理完了を待ち、その処理結果を取得する」といった非同期処理を実現するためのクラスであり、promise
クラスと組み合わせて使用する。promise
が別スレッドでの処理結果を書き込み、future
がその結果を読み取る。promise
とfuture
は内部的に同一の共有状態を参照する。これによってスレッド間での値の受け渡しやスレッド間同期を実現する。このクラスはR&
およびvoid
の、2つの特殊化を持つ。
名前 |
説明 |
対応バージョン |
get |
結果を取得する |
C++11 |
名前 |
説明 |
対応バージョン |
valid |
共有状態を持っているかを確認する |
C++11 |
名前 |
説明 |
対応バージョン |
wait |
処理が完了するまで待機する |
C++11 |
wait_for |
相対時間でタイムアウトを指定して、処理が完了するまで待機する |
C++11 |
wait_until |
絶対時間でタイムアウトを指定して、処理が完了するまで待機する |
C++11 |
#include <iostream>
#include <future>
#include <thread>
#include <utility>
void calc(std::promise<int> p)
{
int sum = 0;
for (int i = 0; i < 10; ++i) {
sum += i + 1;
}
p.set_value(sum); // 結果値を書き込む
}
int main()
{
std::promise<int> p;
std::future<int> f = p.get_future();
// 別スレッドで計算を行う
std::thread t(calc, std::move(p));
// calc()によって書き込まれた結果を取得
std::cout << f.get() << std::endl;
t.join();
}
- std::future[color ff0000]
- std::promise[link promise.md]
- p.set_value[link promise/set_value.md]
- p.get_future()[link promise/get_future.md]
- std::move[link /reference/utility/move.md]
- f.get()[link future/get.md]