Skip to content

Latest commit

 

History

History
108 lines (80 loc) · 3.59 KB

future.md

File metadata and controls

108 lines (80 loc) · 3.59 KB

future

  • 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がその結果を読み取る。promisefutureは内部的に同一の共有状態を参照する。これによってスレッド間での値の受け渡しやスレッド間同期を実現する。このクラスはR&およびvoidの、2つの特殊化を持つ。

メンバ関数

名前 説明 対応バージョン
(constructor) コンストラクタ C++11
(destructor) デストラクタ C++11
operator= 代入演算子 C++11
share futureオブジェクトを共有する C++11

値の取得

名前 説明 対応バージョン
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]

出力

55

バージョン

言語

  • C++11

処理系

  • Clang: ??
  • GCC: 4.7.0
  • ICC: ??
  • Visual C++: 2012
    • 2012段階のstd::threadクラスは、コンストラクタに引数をムーブで渡すことができない。そのため、promiseオブジェクトはスレッド間の共有オブジェクトにする必要がある。(所有権が曖昧になるため、スタイルとしてはよくない) #737812 - std::thread does not accept std::move

参照