pcntl_wait
(PHP 5, PHP 7)
pcntl_wait — Ожидает или возвращает статус порожденного дочернего процесса
Описание
&$status
, int $options
= 0
, array &$rusage
= ?
) : intФункция ожидания приостанавливает выполнение текущего процесса до тех пор, пока дочерний процесс не завершится или пока не будет получен сигнал который завершает текущий процесс или вызывает функцию обработки сигнала. Если дочерний процесс уже завершился ко времени вызова (так называемые "зомби" процессы), функция незамедлительно вернёт управление. Обратитесь к вашей системному рукодводству (man) wait(2) для уточнения специфики работы wait в вашей системе.
Замечание:
Эта функция эквивалентна вызову pcntl_waitpid() с аргументом
pid
равным-1
и без аргументаoptions
.
Список параметров
-
status
-
pcntl_wait() разместит информацию о статусе по ссылке в аргументе
status
, который может быть передан в слудующие функции: pcntl_wifexited(), pcntl_wifstopped(), pcntl_wifsignaled(), pcntl_wexitstatus(), pcntl_wtermsig() и pcntl_wstopsig(). -
options
-
Если системный вызов wait3 (man 2 wait3) доступен в вашей системе (как правило в BSD-подобных системах), вы можете задать необязательный аргумент
options
. Если этот параметр не задан, будет использован стандатный системный вызов wait. Если системный вызов wait3 не доступен для вашей системы, передача значения аргументаoptions
не будет иметь значения. Значение аргументаoptions
- это битовая маска, которая может принимать значение ноль или более путем логического объединения следующих констант:Возможные значения для options
WNOHANG
Незамедлительно вернуть управление, если ни один из дочерних процессов не завершен WUNTRACED
Вернуть управление для остановленных дочерних процессов, о статусе которых ещё не сообщено
Возвращаемые значения
pcntl_wait() возвращает ID завершенного дочернего процесса,
-1 при ошибке или ноль, если WNOHANG
был передан в аргумент
options
(на системах с доступным системным вызовом wait3)
и не было доступных дочерних процессов.
Смотрите также
- pcntl_fork() - Разветвить (fork) текущий запущенный процесс
- pcntl_signal() - Установка обработчика сигнала
- pcntl_wifexited() - Проверяет, соответствует ли код завершения процесса нормальному завершению
- pcntl_wifstopped() - Проверить, остановлен ли дочерний процесс
- pcntl_wifsignaled() - Проверить, соответствует ли код завершения процесса завершению по сигналу
- pcntl_wexitstatus() - Получить код возврата завершенного дочернего процесса
- pcntl_wtermsig() - Получить сигнал, из-за которого был принудительно завершен дочерний процесс
- pcntl_wstopsig() - Получить сигнал, из-за которого был остановлен дочерний процесс
- pcntl_waitpid() - Ожидает или возвращает статус порожденного дочернего процесса