名前空間
変種
操作

std::jthread::join

From cppreference.com
< cpp‎ | thread‎ | jthread
 
 
並行性サポートライブラリ
スレッド
(C++11)
(C++20)
this_thread 名前空間
(C++11)
(C++11)
(C++11)
協調的なキャンセル
排他制御
(C++11)
汎用ロック管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
条件変数
(C++11)
セマフォ
ラッチとバリア
(C++20)
(C++20)
future
(C++11)
(C++11)
(C++11)
(C++11)
安全なメモリ解放 (Safe Reclamation)
(C++26)
ハザードポインタ
アトミック型
(C++11)
(C++20)
アトミック型の初期化
(C++11)(C++20で非推奨)
(C++11)(C++20で非推奨)
メモリオーダー
(C++11)(C++26で非推奨)
アトミック操作のためのフリー関数
アトミックフラグのためのフリー関数
 
 
void join();
(C++20以降)

現在のスレッドを、*thisが識別するスレッドの実行が完了するまでブロックします。

*thisが識別するスレッドの完了は、join()からの対応する成功した復帰と同期します

*this自体には同期は実行されません。複数のスレッドから同じjthreadオブジェクトに対して同時にjoin()を呼び出すことは、未定義の動作をもたらすデータ競合を構成します。

目次

[編集] パラメータ

(なし)

[編集] 戻り値

(なし)

[編集] 事後条件

joinable()false です。

[編集] 例外

エラーが発生した場合、std::system_error

[編集] エラー条件

[編集]

#include <chrono>
#include <iostream>
#include <thread>
 
void foo()
{
    // simulate expensive operation
    std::this_thread::sleep_for(std::chrono::seconds(1));
}
 
void bar()
{
    // simulate expensive operation
    std::this_thread::sleep_for(std::chrono::seconds(1));
}
 
int main()
{
    std::cout << "starting first helper...\n";
    std::jthread helper1(foo);
 
    std::cout << "starting second helper...\n";
    std::jthread helper2(bar);
 
    std::cout << "waiting for helpers to finish..." << std::endl;
    helper1.join();
    helper2.join();
 
    std::cout << "done!\n";
}

出力

starting first helper...
starting second helper...
waiting for helpers to finish...
done!

[編集] 参考文献

  • C++23標準 (ISO/IEC 14882:2024)
  • 33.4.4.3 Members [thread.jthread.mem]
  • C++20 standard (ISO/IEC 14882:2020)
  • 32.4.3.2 Members [thread.jthread.mem]

[編集] 関連項目

スレッドがスレッドハンドルから独立して実行を継続できるようにする
(public member function) [編集]
スレッドが join 可能か、すなわち並行コンテキストで実行されている可能性があるかをチェックする
(public member function) [編集]
Cドキュメントthrd_joinについて)
English 日本語 中文(简体) 中文(繁體)