Skip to content

Latest commit

 

History

History
73 lines (49 loc) · 1.61 KB

join.md

File metadata and controls

73 lines (49 loc) · 1.61 KB

join

  • thread[meta header]
  • std[meta namespace]
  • jthread[meta class]
  • function[meta id-type]
  • cpp20[meta cpp]
void join();

概要

スレッドが終了するまで待機する

要件

threadオブジェクトにスレッドが関連付けられていること(joinable() == true)。

効果

thisに関連付けれられたスレッドが完了するまで、この関数を呼び出したスレッドをブロックする。

同期操作

関連付けられたスレッドの完了は、join()メンバ関数の正常リターンに対して同期する

つまり、「thisに関連付けられたスレッドT1上で行われる全処理の完了」は、 「join()メンバ関数を呼び出したスレッドT0上での同メンバ関数からの正常リターン」よりも前に発生する

事後条件

thisは何も指さない空のthreadオブジェクトとなる。

例外

join操作に失敗した場合、system_error例外を投げる。

#include <cassert>
#include <thread>

int main()
{
  int x = 0;
  std::jthread t([&]{ ++x; });

  // ここでxにアクセスするとdata raceにより未定義動作

  t.join();

  // 別スレッド上で行われた全処理が完了している
  assert(x == 1);

  return 0;
}
  • join()[color ff0000]

出力

バージョン

言語

  • C++20

処理系