(PHP 5, PHP 7, PHP 8)
pcntl_wait — 等待或返回 fork 的子进程状态
&$status
, int $options
= 0
, array &$rusage
= ?
) : intwait函数挂起当前进程的执行直到一个子进程退出或接收到一个信号要求中断当前进程或调用一个信号处理函数。如果一个子进程在调用此函数时已经退出(俗称僵尸进程),此函数立刻返回。子进程使用的所有系统资源将被释放。关于 wait 在您系统上工作的详细规范请查看您系统的 wait(2)手册。
注意:
这个函数等同于以
-1
作为参数pid
的值并且没有options
参数来调用 pcntl_waitpid() 函数。
status
pcntl_wait() 将会存储状态信息到 status
参数上,这个通过 status
参数返回的状态信息可以用以下函数
pcntl_wifexited(),
pcntl_wifstopped(),
pcntl_wifsignaled(),
pcntl_wexitstatus(),
pcntl_wtermsig() 以及
pcntl_wstopsig() 获取其具体的值。
options
如果您的操作系统(多数BSD类系统)允许使用 wait3,您可以提供可选的options
参数。如果这个参数没有提供,wait将会被用作系统调用。如果wait3不可用,提供参数
options
不会有任何效果。options
的值可以是0
或者以下两个常量或两个常量“或运算”结果(即两个常量代表意义都有效)。
WNOHANG |
如果没有子进程退出立刻返回。 |
WUNTRACED |
子进程已经退出并且其状态未报告时返回。 |
pcntl_wait() 返回退出的子进程进程号,发生错误时返回 -1,如果提供了 WNOHANG 作为 option(wait3可用的系统)并且没有可用子进程时返回 0。