pcntl_waitpid
(PHP 4 >= 4.1.0, PHP 5, PHP 7, PHP 8)
pcntl_waitpid — 等待或返回 fork 的子进程状态
说明
挂起当前进程的执行直到参数 process_id 指定的进程号的进程退出,
或接收到一个信号要求中断当前进程或调用一个信号处理函数。
如果 process_id 指定的子进程在此函数调用时已经退出(俗称僵尸进程),此函数
将立刻返回。关于 waitpid 更详细的规范请参见系统的 waitpid(2)手册。
参数
process_id-
参数
process_id的值可以是以下之一:process_id可选值< -1等待任意进程组 ID 等于参数 process_id给定值的绝对值的进程。-1等待任意子进程;与 pcntl_wait() 函数行为一致。 0等待任意与调用进程组 ID 相同的子进程。 > 0等待进程号等于参数 process_id值的子进程。注意:
指定
-1作为process_id的值等同于 pcntl_wait() 提供(负的flags)。
status
pcntl_waitpid() 将会存储状态信息到 status
参数上,这个通过 status 参数返回的状态信息可以用以下函数
pcntl_wifexited()、
pcntl_wifstopped()、
pcntl_wifsignaled()、
pcntl_wexitstatus()、
pcntl_wtermsig() 以及
pcntl_wstopsig() 获取其具体的值。
flags
flags 的值可以是以下两个常量中 0 个或多个 OR 运算的结果:
WNOHANG |
如果没有子进程退出立刻返回。 |
WUNTRACED |
子进程已经退出并且其状态未报告时返回。 |
返回值
pcntl_waitpid() 返回退出的子进程进程号,发生错误时返回 -1,如果使用
WNOHANG 并且没有可用子进程时返回 0。
参见
- pcntl_fork() - 在当前进程当前位置产生分叉(fork)
- pcntl_signal() - 安装信号处理程序
- pcntl_wifexited() - 检查状态代码是否代表一个正常的退出
- pcntl_wifstopped() - 检查子进程当前是否已经停止
- pcntl_wifsignaled() - 检查子进程状态码是否代表由于某个信号而中断
- pcntl_wexitstatus() - 返回一个中断的子进程的返回代码
- pcntl_wtermsig() - 返回导致子进程中断的信号
- pcntl_wstopsig() - 返回导致子进程停止的信号