PHP Conference Fukuoka 2025

pcntl_waitpid

(PHP 4 >= 4.1.0, PHP 5, PHP 7, PHP 8)

pcntl_waitpidAguarda ou retorna o status de um filho bifurcado

Descrição

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

Suspende a execução do processo atual até que um filho, conforme especificado pelo argumento process_id, tenha saído, ou até que um sinal seja entregue, cuja ação seja encerrar o processo atual ou chamar uma função de tratamento de sinal.

Se um filho, conforme solicitado por process_id, já tiver saído no momento da chamada (um processo chamado "zumbi"), a função retorna imediatamente. Quaisquer recursos do sistema utilizados pelo filho são liberados. Consulte a página de manual waitpid(2) do sistema para obter detalhes específicos sobre como o waitpid funciona.

Parâmetros

process_id

O valor de process_id pode ser um dos seguintes:

Valores possíveis para process_id
< -1 aguarda qualquer processo filho cujo ID do grupo de processos seja igual ao valor absoluto de process_id.
-1 aguarda qualquer processo filho; este é o mesmo comportamento que a função pcntl_wait() exibe.
0 aguarda qualquer processo filho cujo ID do grupo de processos seja igual ao do processo de chamada.
> 0 aguarda o filho cujo ID do processo é igual ao valor de process_id.

Nota:

Especificar -1 como process_id é equivalente à funcionalidade que pcntl_wait() fornece (menos flags).

status

pcntl_waitpid() armazenará informações de status no parâmetro status, que podem ser avaliadas usando as seguintes funções: pcntl_wifexited(), pcntl_wifstopped(), pcntl_wifsignaled(), pcntl_wexitstatus(), pcntl_wtermsig() e pcntl_wstopsig().

flags

O valor de flags é o valor de zero ou mais das duas constantes globais a seguir combinadas com OR:

Valores possíveis para flags
WNOHANG Retorna imediatamente se nenhum processo filho tiver saído.
WUNTRACED Retorna para filhos que estão parados e cujos status não tenham sido reportados.

Valor Retornado

pcntl_waitpid() retorna o ID do processo do filho que saiu, -1 em caso de erro ou zero se WNOHANG foi usado e nenhum filho estava disponível.

Veja Também

adicionar nota

Notas de Usuários 3 notes

up
3
saguto dot l7cc at gmail dot com
17 years ago
please note, if you using configure option --enable-sigchild(Enable PHP's own SIGCHLD handler) when complie php(under linux 2.6.18-53.1.13.el5.centos.plus and php 5.2.5 as I know), pcntl_waitpid and pcntl_wait in php script would never return the child pid, because the build in handle get it first.
up
0
fx4084 at gmail dot com
11 years ago
<?php$childs = array();// Fork some process.for($i = 0; $i < 10; $i++) {    $pid = pcntl_fork();    if($pid == -1)        die('Could not fork');    if ($pid) {        echo "parent \n";        $childs[] = $pid;    } else {        // Sleep $i+1 (s). The child process can get this parameters($i).        sleep($i+1);                // The child process needed to end the loop.        exit();    }}while(count($childs) > 0) {    foreach($childs as $key => $pid) {        $res = pcntl_waitpid($pid, $status, WNOHANG);                // If the process has already exited        if($res == -1 || $res > 0)            unset($childs[$key]);    }        sleep(1);}?>
up
-1
renmengyang567 at gmail dot com
6 years ago
<?phpdeclare(ticks = 1);function zp_handler($signal) {    $id = pcntl_waitpid(-1, $status, WNOHANG);    if (pcntl_wifexited($status))     {        printf("Removed Chlid id: %d \n",$id);        printf("Chlid status: %d \n",pcntl_wexitstatus($status));    }}//pcntl_signal_dispatch();pcntl_signal(SIGCHLD, "zp_handler");//pcntl_signal_dispatch();//$pid = pcntl_fork();if ($pid == 0){    print "#1 Hi, I'm child process".PHP_EOL;    sleep(3);    return 10;}else {    print "#1parent process id:".$pid.PHP_EOL;    $pid = pcntl_fork();    if ($pid == 0)    {   print "#2 Hi, I'm child process".PHP_EOL;        sleep(10);        exit(20);    }     else     {        print "#2parent process id:".$pid.PHP_EOL;        for ($i=0; $i <10 ; $i++) {             print "wait..".PHP_EOL;            sleep(10);        }    }}?>
To Top