pcntl_waitpid

待つかフォークした子プロセスのステータスを返す

説明

int pcntl_waitpid(
    int $process_id,
    int &$status,
    int $flags = 0,
    array &$resource_usage = []
)

引数 process_id で指定した子プロセスが終了する・ 現在のプロセスを終了させるシグナルが送信される・シグナル処理関数を コールするシグナルが送信される のいずれかが発生するまで、現在のプロセスの実行を中断します。

process_id でリクエストされた子プロセスが、 コール時に既に終了している場合("ゾンビ"プロセスと呼ばれます)、 この関数は直ちに処理を返します。 子プロセスにより使用される全てのシステム リソースは、解放されます。waitpid のシステムでの動作に関する詳細は、 システムの waitpid(2) についての man ページを参照ください。

パラメータ

process_id

process_id の値は、次のどれかとなります。

process_id のとりうる値
< -1 プロセスグループ ID が process_id の絶対値に等しい 子プロセスを待ちます。
-1 全ての子プロセスを待ちます。これは、wait 関数の動作と同じです。
0 プロセスグループ ID がコール側のプロセスと等しい子プロセスを 待ちます。
> 0 プロセス ID が process_id の値に等しい 子プロセスを待ちます。

注意:

-1process_id に指定した際の動きは、 pcntl_wait の機能と (flags を除いて) 同じです。

status

pcntl_waitpid は、パラメータ status の中にステータス情報を保存します。 このステータスは、次の関数を用いて評価可能です。 pcntl_wifexitedpcntl_wifstoppedpcntl_wifsignaledpcntl_wexitstatuspcntl_wtermsig および pcntl_wstopsig

flags

flags の値は、次の 2 つのグローバル定数の ゼロまたはそれ以上の論理和です。

flags のとりうる値
WNOHANG 子プロセスが終了していない場合に直ちに処理を返します。
WUNTRACED 停止した子プロセスの場合に処理を返します。そして、ステータス は報告されません。

戻り値

pcntl_waitpid は、終了した子プロセスの プロセス ID を返します。エラーの場合は -1、WNOHANG が使用され、 子プロセスが利用できない場合に 0 を返します。

参考

  • pcntl_fork
  • pcntl_signal
  • pcntl_wifexited
  • pcntl_wifstopped
  • pcntl_wifsignaled
  • pcntl_wexitstatus
  • pcntl_wtermsig
  • pcntl_wstopsig