PHP pcntl_wait 进程控制函数

  • 定义和用法

    pcntl_wait - 等待或返回fork的子进程状态
  • 版本支持

    PHP4 PHP5 PHP7
    不支持 支持 支持
  • 语法

    pcntl_wait( int &$status [, int $options = 0 ] )
    pcntl_wait() 函数刮起当前进程的执行直到一个子进程退出或接收到一个信号要求中断当前进程或调用一个信号处理函数。如果一个子进程在调用此函数时已经退出(俗称僵尸进程),此函数立刻返回。子进程使用的所有系统资源将 被释放。关于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 pcntl_wait()如果您的操作系统(多数BSD类系统)允许使用wait3,您可以提供可选的options 参数。如果这个参数没有提供,wait将会被用作系统调用。如果wait3不可用,提供参数options不会有任何效果。options的值可以是0 或者以下两个常量或两个常量“或运算”结果(即两个常量代表意义都有效)。 option可用的值:
    • WNOHANG 如果没有子进程退出立刻返回。
    • WUNTRACED 子进程已经退出并且其状态未报告时返回。
  • 返回值

    pcntl_wait()返回退出的子进程进程号,发生错误时返回-1,如果提供了 WNOHANG作为option(wait3可用的系统)并且没有可用子进程时返回0。
  • 示例

    下面例子演示多进程示例:
    define("MAXPROCESS",25);
    $execute = 0;
    for ($i=0;$i<100;$i++){
        $pid = pcntl_fork();
    
        if ($pid == -1) {
             die("could not fork");
        } elseif ($pid) {
             echo "I'm the Parent $i<br/>";
             $execute++;
             if ($execute>=MAXPROCESS){
                  pcntl_wait($status);
                  $execute--;
             }
        } else {
             echo "I am the child, $i pid = $pid <br/>";
             sleep(rand(1,3));
             echo "Bye Bye from $i<br/>";
             exit;
        }
    }
    
  • 相关页面

    pcntl_fork() - 在当前进程当前位置产生分支(子进程)。译注:fork是创建了一个子进程,父进程和子进程 都从fork的位置开始向下继续执行,不同的是父进程执行过程中,得到的fork返回值为子进程 号,而子进程得到的是0。
    pcntl_signal() - 安装一个信号处理器
    pcntl_wifexited() - 检查状态代码是否代表一个正常的退出。
    pcntl_wifstopped() - 检查子进程当前是否已经停止
    pcntl_wifsignaled() - 检查子进程状态码是否代表由于某个信号而中断
    pcntl_wexitstatus() - 返回一个中断的子进程的返回代码
    pcntl_wtermsig() - 返回导致子进程中断的信号
    pcntl_wstopsig() - 返回导致子进程停止的信号
    pcntl_waitpid() - 等待或返回fork的子进程状态