array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ja', ), 'this' => array ( 0 => 'function.pcntl-waitpid.php', 1 => 'pcntl_waitpid', ), 'up' => array ( 0 => 'ref.pcntl.php', 1 => 'PCNTL 関数', ), 'prev' => array ( 0 => 'function.pcntl-wait.php', 1 => 'pcntl_wait', ), 'next' => array ( 0 => 'function.pcntl-wexitstatus.php', 1 => 'pcntl_wexitstatus', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ja', 'path' => 'reference/pcntl/functions/pcntl-waitpid.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 4 >= 4.1.0, PHP 5, PHP 7, PHP 8)
pcntl_waitpid — 待つかフォークした子プロセスのステータスを返す
引数 process_id
で指定した子プロセスが終了する・
現在のプロセスを終了させるシグナルが送信される・シグナル処理関数を
コールするシグナルが送信される
のいずれかが発生するまで、現在のプロセスの実行を中断します。
process_id
でリクエストされた子プロセスが、
コール時に既に終了している場合("ゾンビ"プロセスと呼ばれます)、
この関数は直ちに処理を返します。
子プロセスにより使用される全てのシステム
リソースは、解放されます。waitpid のシステムでの動作に関する詳細は、
システムの waitpid(2) についての man ページを参照ください。
process_id
process_id
の値は、次のどれかとなります。
< -1 |
プロセスグループ ID が process_id の絶対値に等しい
子プロセスを待ちます。
|
-1 |
全ての子プロセスを待ちます。これは、wait 関数の動作と同じです。 |
0 |
プロセスグループ ID がコール側のプロセスと等しい子プロセスを 待ちます。 |
> 0 |
プロセス ID が process_id の値に等しい
子プロセスを待ちます。
|
注意:
-1
をprocess_id
に指定した際の動きは、 pcntl_wait() の機能と (flags
を除いて) 同じです。
status
pcntl_waitpid() は、パラメータ
status
の中にステータス情報を保存します。
このステータスは、次の関数を用いて評価可能です。
pcntl_wifexited()、
pcntl_wifstopped()、
pcntl_wifsignaled()、
pcntl_wexitstatus()、
pcntl_wtermsig() および
pcntl_wstopsig() 。
flags
flags
の値は、次の 2 つのグローバル定数の
ゼロまたはそれ以上の論理和です。
WNOHANG |
子プロセスが終了していない場合に直ちに処理を返します。 |
WUNTRACED |
停止した子プロセスの場合に処理を返します。そして、ステータス は報告されません。 |
pcntl_waitpid() は、終了した子プロセスの
プロセス ID を返します。エラーの場合は -1、WNOHANG
が使用され、
子プロセスが利用できない場合に 0 を返します。