std::shared_future<T>::wait
From cppreference.com
< cpp | スレッド | shared_future
| void wait() const; |
(C++11以降) | |
結果が利用可能になるまでブロックします。valid() == true が呼び出し後に成り立ちます。
この関数を呼び出す前に valid() == false の場合、動作は未定義です。
目次 |
[編集] パラメータ
(なし)
[編集] 戻り値
(なし)
[編集] 例外
実装定義の例外をスローする場合があります。
[編集] 注記
実装は、呼び出し前に valid() == false となるケースを検出して、std::future_error を std::future_errc::no_state のエラー条件でスローすることが推奨されます。
複数のスレッドから同じ std::shared_future に対して wait を呼び出すことは安全ではありません。意図された使用法は、同じ共有状態を待機する各スレッドが std::shared_future のコピーを持つことです。
[編集] 例
このコードを実行
#include <chrono> #include <future> #include <iostream> #include <thread> int fib(int n) { if (n < 3) return 1; else return fib(n - 1) + fib(n - 2); } int main() { std::shared_future<int> f1 = std::async(std::launch::async, []() { return fib(40); }); std::shared_future<int> f2 = std::async(std::launch::async, []() { return fib(43); }); std::cout << "waiting... " << std::flush; const auto start = std::chrono::system_clock::now(); f1.wait(); f2.wait(); const auto diff = std::chrono::system_clock::now() - start; std::cout << std::chrono::duration<double>(diff).count() << " seconds\n"; std::cout << "f1: " << f1.get() << '\n'; std::cout << "f2: " << f2.get() << '\n'; }
実行結果の例
waiting... 1.61803 seconds f1: 102334155 f2: 433494437
[編集] 関連項目
| 指定されたタイムアウト時間内に結果が利用可能でない場合、待機して戻ります。 (public member function) | |
| 指定された時刻までに結果が利用可能でない場合、待機して戻ります。 (public member function) |