Provided by: manpages-ja-dev_0.5.0.0.20221215+dfsg-1_all bug

名前

       pthread_join - 終了したスレッドを join する

書式

       #include <pthread.h>

       int pthread_join(pthread_t thread, void **retval);

       -pthread を付けてコンパイルとリンクを行う。

説明

       pthread_join()  関数は、thread で指定されたスレッドが 終了するのを待つ。そのスレッドがすで
       に終了している場合、 pthread_join() はすぐに返る。 thread で指定されたスレッドは join 可能
       でなければならない。

       retval  が NULL でない場合、 pthread_join() は対象スレッドの終了ステータス (すなわち、対象
       スレッドが pthread_exit(3) に渡した値)  を  retval  が指す場所にコピーする。対象スレッドが
       キャンセルされた場合、 retval が指す場所には PTHREAD_CANCELED が格納される。

       複数のスレッドが同時に同じスレッドを     join     しようとした場合、その結果    は不定であ
       る。pthread_join() を呼び出しているスレッドがキャンセル された場合、対象スレッドは join 可
       能のままとなる (detached 状態には ならない)。

返り値

       成功すると、 pthread_join() は 0 を返す。エラーの場合、エラー番号を返す。

エラー

       EDEADLK
              デッドロックが検出された   (例えば、二つのスレッドが互いに   join  しようと  した場
              合)、または thread に呼び出したスレッドが指定されている。

       EINVAL thread が join 可能なスレッドではない。

       EINVAL 別のスレッドがすでにこのスレッドの join 待ちである。

       ESRCH  ID が thread のスレッドが見つからなかった。

属性

       この節で使用されている用語の説明については、 attributes(7) を参照。

       ┌─────────────────┬───────────────┬─────────┐
       │インターフェース属性      │
       ├─────────────────┼───────────────┼─────────┤
       │pthread_join()   │ Thread safety │ MT-Safe │
       └─────────────────┴───────────────┴─────────┘

準拠

       POSIX.1-2001, POSIX.1-2008.

注意

       After a successful call to pthread_join(), the caller is guaranteed that the target thread
       has  terminated.   The  caller  may  then choose to do any clean-up that is required after
       termination of the thread (e.g., freeing memory or other resources that were allocated  to
       the target thread).

       すでに join されたスレッドを join した場合の結果は不定である。

       join 可能なスレッド (detached 状態でないスレッド) の join に失敗した場合、 "ゾンビスレッド
       (zombie thread)" が生成される。 各ゾンビスレッドはシステムリソースをいくらかは消費し、  ゾ
       ンビスレッドがたくさん生成されてしまうと、  新しいスレッド (やプロセス) がそれ以上作成でき
       なくなってしまうので、 このようなことが起きるのは避けること。

       pthreads には、 waitpid(-1, &status, 0)、つまり "終了されたスレッドのどれかを  join  する"
       といった機能はない。 この機能が必要だと思うような場合には、おそらく 自分のアプリケーション
       の設計を考え直す必要があるだろう。

       プロセス内の全てのスレッドは対等であり、  どのスレッドでもプロセス内の他のスレッドを  join
       できる。

       pthread_create(3) を参照。

関連項目

       pthread_cancel(3),       pthread_create(3),       pthread_detach(3),      pthread_exit(3),
       pthread_tryjoin_np(3), pthreads(7)

この文書について

       この man ページは Linux man-pages プロジェクトのリリース 5.10 の一部である。プロジェクトの
       説明とバグ報告に関する情報は https://www.kernel.org/doc/man-pages/ に書かれている。