Skip to content

Latest commit

 

History

History
90 lines (63 loc) · 2.08 KB

File metadata and controls

90 lines (63 loc) · 2.08 KB

reset

  • future[meta header]
  • std[meta namespace]
  • packaged_task[meta class]
  • function[meta id-type]
  • cpp11[meta cpp]
void reset();

概要

共有状態を作り直す。

一度タスクを実行したのちは共有状態への結果値の再格納ができないため、同じpackaged_taskオブジェクトの同じ関数(タスク)を再度非同期実行したい場合に使用する。

効果

*this = packaged_task(std::move(f));
  • std::move[link /reference/utility/move.md]

によって、新たに共有状態を作成する。古い共有状態は放棄される。

fはメンバ変数として保持している、非同期実行する関数オブジェクト。

戻り値

なし

例外

この関数は、以下の例外を送出する可能性がある:

  • bad_alloc : 新たな共有状態のアロケートに失敗
  • タスクfのムーブコンストラクタが送出するあらゆる例外
  • future_error : 共有状態を持っていない状態でこの関数を呼び出した場合、no_stateをerror conditionにして送出する

#include <iostream>
#include <future>

int calc() { return 3; }

void execute(std::packaged_task<int()>& task)
{
  std::future<int> f = task.get_future(); // 結果値取得のためのfutureを取得
  task();
  std::cout << f.get() << std::endl;
}

int main()
{
  std::packaged_task<int()> task(calc); // calc()を非同期タスクとして登録

  execute(task); // タスクを実行

  task.reset(); // 共有状態を作り直す

  execute(task); // タスクを再度実行
}
  • reset()[color ff0000]
  • task.get_future()[link get_future.md]
  • std::future[link /reference/future/future.md]
  • f.get()[link /reference/future/future/get.md]

出力

3
3

バージョン

言語

  • C++11

処理系

参照