无需言 做自己 业 ,精于勤 荒于嬉.

PCNTL 函数 pcntl_wait 等待或返回 fork 的子进程状态

发表日期:2021-07-01 08:56:17 | 来源: | 分类:PCNTL 函数

pcntl_wait

(PHP 5, PHP 7, PHP 8)

pcntl_wait等待或返回 fork 的子进程状态

说明

pcntl_wait(int &$status, int $options = 0, array &$rusage = ?): int

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

如果您的操作系统(多数BSD类系统)允许使用 wait3,您可以提供可选的options 参数。如果这个参数没有提供,wait将会被用作系统调用。如果wait3不可用,提供参数 options 不会有任何效果。options 的值可以是0 或者以下两个常量或两个常量“或运算”结果(即两个常量代表意义都有效)。

options可用值
WNOHANG 如果没有子进程退出立刻返回。
WUNTRACED 子进程已经退出并且其状态未报告时返回。

返回值

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

参见

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

阅读全文 »

PCNTL 函数 pcntl_wifsignaled 检查子进程状态码是否代表由于某个信号而中断

发表日期:2021-07-01 08:56:17 | 来源: | 分类:PCNTL 函数

pcntl_wifsignaled

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

pcntl_wifsignaled检查子进程状态码是否代表由于某个信号而中断

说明

pcntl_wifsignaled(int $status): bool

检查子进程是否是由于某个未捕获的信号退出的。

参数

status

参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。

返回值

如果子进程是由于某个未捕获的信号退出的返回 true ,其他情况返回 false

参见

阅读全文 »

PCNTL 函数 pcntl_wtermsig 返回导致子进程中断的信号

发表日期:2021-07-01 08:56:17 | 来源: | 分类:PCNTL 函数

pcntl_wtermsig

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

pcntl_wtermsig返回导致子进程中断的信号

说明

pcntl_wtermsig(int $status): int

返回导致子进程中断的信号编号。这个函数仅在pcntl_wifsignaled() 返回 true 时有效。

参数

status

参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。

返回值

返回整型的信号编号。

参见

阅读全文 »

PCNTL 函数 pcntl_errno 别名 pcntl_get_last_error()

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_errno

(PHP 5 >= 5.3.4, PHP 7, PHP 8)

pcntl_errno别名 pcntl_get_last_error()

说明

此函数是该函数的别名: pcntl_get_last_error()

阅读全文 »

PCNTL 函数 pcntl_getpriority 获取任意进程的优先级

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_getpriority

(PHP 5, PHP 7, PHP 8)

pcntl_getpriority获取任意进程的优先级

说明

pcntl_getpriority(int $pid = getmypid(), int $process_identifier = PRIO_PROCESS): int

pcntl_getpriority() 获取进程号为 pid的进程的优先级。由于不同的系统类型以及内核版本下 优先级可能不同,因此请参考您系统的getpriority(2)手册以获取详细的规范。

参数

pid

如果没有指定,默认是当前进程的进程号。

process_identifier

PRIO_PGRP(译注:获取进程组优先级), PRIO_USER (译注:获取用户进程优先级)或 PRIO_PROCESS(译注:默认值;获取进程优先级)三者之一。

返回值

pcntl_getpriority() 返回进程的优先级或在错误时返回 false 。 值越小代表优先级越高。

警告

此函数可能返回布尔值 false,但也可能返回等同于 false 的非布尔值。请阅读 布尔类型章节以获取更多信息。应使用 === 运算符来测试此函数的返回值。

参见

阅读全文 »

PCNTL 函数 pcntl_setpriority 修改任意进程的优先级

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_setpriority

(PHP 5, PHP 7, PHP 8)

pcntl_setpriority修改任意进程的优先级

说明

pcntl_setpriority(int $priority, int $pid = getmypid(), int $process_identifier = PRIO_PROCESS): bool

pcntl_setpriority() 设置进程号为 pid的进程的优先级。

参数

priority

priority 通常时-20至20这个范围内的值。默认优先级是0,值越小代表 优先级越高。由于不同的系统类型以及内核版本下优先级可能不同,因此请参考您系统的setpriority(2) 手册以获取详细的规范。

pid

如果没有指定,默认是当前进程的进程号。

process_identifier

PRIO_PGRP(译注:获取进程组优先级), PRIO_USER (译注:获取用户进程优先级)或 PRIO_PROCESS(译注:默认值;获取进程优先级)三者之一。

返回值

成功时返回 true, 或者在失败时返回 false

参见

阅读全文 »

PCNTL 函数 pcntl_signal_dispatch 调用等待信号的处理器

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

      示例1
<?php 
echo "安装信号处理器...\n";
pcntl_signal(SIGHUP,  function($signo) {
     echo "信号处理器被调用\n";
}
);
echo "为自己生成SIGHUP信号...\n";
posix_kill(posix_getpid(), SIGHUP);
echo "分发...\n";
pcntl_signal_dispatch();
echo "完成\n";
?>

阅读全文 »

PCNTL 函数 pcntl_signal_get_handler Get the current handler for specified signal

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

      示例1
<?php 
var_dump(pcntl_signal_get_handler(SIGUSR1));
 // Outputs: int(0)function pcntl_test($signo) {
}
pcntl_signal(SIGUSR1, 'pcntl_test');
var_dump(pcntl_signal_get_handler(SIGUSR1));
 // Outputs: string(10) "pcntl_test"pcntl_signal(SIGUSR1, SIG_DFL);
var_dump(pcntl_signal_get_handler(SIGUSR1));
 // Outputs: int(0)pcntl_signal(SIGUSR1, SIG_IGN);
var_dump(pcntl_signal_get_handler(SIGUSR1));
 // Outputs: int(1)?>

阅读全文 »

PCNTL 函数 pcntl_sigprocmask 设置或检索阻塞信号

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

      示例1
<?php 
//将SIGHUP信号加入到阻塞信号中pcntl_sigprocmask(SIG_BLOCK, array(SIGHUP));
$oldset = array();
//将SIGHUP从阻塞信号列表中移除并返回之前的阻塞信号列表。pcntl_sigprocmask(SIG_UNBLOCK, array(SIGHUP), $oldset);
?>

阅读全文 »

PCNTL 函数 pcntl_get_last_error Retrieve the error number set by the last pcntl function which failed

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_get_last_error

(PHP 5 >= 5.3.4, PHP 7, PHP 8)

pcntl_get_last_errorRetrieve the error number set by the last pcntl function which failed

说明

pcntl_get_last_error(): int

警告

本函数还未编写文档,仅有参数列表。

参数

此函数没有参数。

返回值

Returns error code.

参见

  • pcntl_strerror() - Retrieve the system error message associated with the given errno

阅读全文 »

PCNTL 函数 pcntl_sigwaitinfo 等待信号

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

      示例1
<?php 
echo "Blocking SIGHUP signal\n";
pcntl_sigprocmask(SIG_BLOCK, array(SIGHUP));
echo "Sending SIGHUP to self\n";
posix_kill(posix_getpid(), SIGHUP);
echo "Waiting for signals\n";
$info = array();
pcntl_sigwaitinfo(array(SIGHUP), $info);
?>

阅读全文 »

PCNTL 函数 pcntl_signal 安装一个信号处理器

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

      示例1
<?php 
//使用ticks需要PHP 4.3.0以上版本declare(ticks = 1);
//信号处理函数function sig_handler($signo){
     switch ($signo) {
         case SIGTERM:             // 处理SIGTERM信号             exit;
             break;
         case SIGHUP:             //处理SIGHUP信号             break;
         case SIGUSR1:             echo "Caught SIGUSR1...\n";
             break;
         default:             // 处理所有其他信号     }
}
echo "Installing signal handler...\n";
//安装信号处理器pcntl_signal(SIGTERM, "sig_handler");
pcntl_signal(SIGHUP,  "sig_handler");
pcntl_signal(SIGUSR1, "sig_handler");
// 或者在PHP 4.3.0以上版本可以使用对象方法// pcntl_signal(SIGUSR1, array($obj, "do_something");
echo "Generating signal SIGTERM to self...\n";
//向当前进程发送SIGUSR1信号posix_kill(posix_getpid(), SIGUSR1);
echo "Done\n"?>

阅读全文 »

PCNTL 函数 pcntl_waitpid 等待或返回fork的子进程状态

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_waitpid

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

pcntl_waitpid等待或返回fork的子进程状态

说明

pcntl_waitpid(int $pid, int &$status, int $options = 0): int

挂起当前进程的执行直到参数pid指定的进程号的进程退出, 或接收到一个信号要求中断当前进程或调用一个信号处理函数。

如果pid指定的子进程在此函数调用时已经退出(俗称僵尸进程),此函数 将立刻返回。关于waitpid更详细的规范请参见您系统的waitpid(2)手册。

参数

pid

参数pid的值可以是以下之一:

pid可选值
< -1 等待任意进程组ID等于参数pid给定值的绝对值的进程。
-1 等待任意子进程;与pcntl_wait函数行为一致。
0 等待任意与调用进程组ID相同的子进程。
> 0 等待进程号等于参数pid值的子进程。

注意:

指定-1作为pid的值等同于pcntl_wait() 提供(负的options)。

status

pcntl_waitpid()将会存储状态信息到status 参数上,这个通过status参数返回的状态信息可以用以下函数 pcntl_wifexited(), pcntl_wifstopped(), pcntl_wifsignaled(), pcntl_wexitstatus(), pcntl_wtermsig()以及 pcntl_wstopsig()获取其具体的值。

options

如果您的操作系统(多数BSD类系统)允许使用wait3,您可以提供可选的options 参数。如果这个参数没有提供,wait将会被用作系统调用。如果wait3不可用,提供参数 options不会有任何效果。options的值可以是0 或者以下两个常量或两个常量“或运算”结果(即两个常量代表意义都有效)。

options可用的值
WNOHANG 如果没有子进程退出立刻返回。
WUNTRACED 子进程已经退出并且其状态未报告时返回。

返回值

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

参见

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

阅读全文 »

PCNTL 函数 pcntl_strerror Retrieve the system error message associated with the given errno

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_strerror

(PHP 5 >= 5.3.4, PHP 7, PHP 8)

pcntl_strerrorRetrieve the system error message associated with the given errno

说明

pcntl_strerror(int $errno): string|false

警告

本函数还未编写文档,仅有参数列表。

参数

errno

返回值

Returns error description on success 或者在失败时返回 false.

参见

阅读全文 »

PCNTL 函数 pcntl_sigtimedwait 带超时机制的信号等待

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_sigtimedwait

(PHP 5 >= 5.3.0, PHP 7, PHP 8)

pcntl_sigtimedwait带超时机制的信号等待

说明

pcntl_sigtimedwait(
    array $set,
    array &$siginfo = ?,
    int $seconds = 0,
    int $nanoseconds = 0
): int

函数pcntl_sigtimedwait()实际上与pcntl_sigwaitinfo() 的行为一致,不同在于它多了两个增强参数secondsnanoseconds,这使得脚本等待的事件有了一个时间的上限。

参数

set

要等待的信号列表数组。

siginfo

siginfo是一个输出参数,用来返回信号的信息。更详细情况参见 pcntl_sigwaitinfo()

seconds

超时秒数。

nanoseconds

超时纳秒数。

返回值

成功时,函数pcntl_sigtimedwait()返回信号编号。

参见

阅读全文 »

PCNTL 函数 pcntl_wexitstatus 返回一个中断的子进程的返回代码

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_wexitstatus

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

pcntl_wexitstatus返回一个中断的子进程的返回代码

说明

pcntl_wexitstatus(int $status): int

返回一个中断的子进程的返回代码。这个函数仅在函数pcntl_wifexited()返回 true.时有效。

参数

status

参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。

返回值

返回整形的子进程返回代码。

参见

阅读全文 »

PCNTL 函数 pcntl_wifexited 检查状态代码是否代表一个正常的退出。

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_wifexited

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

pcntl_wifexited检查状态代码是否代表一个正常的退出。

说明

pcntl_wifexited(int $status): bool

检查子进程状态代码是否代表正常退出。

参数

status

参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。

返回值

当子进程状态代码代表正常退出时返回 true ,其他情况返回 false

参见

阅读全文 »

PCNTL 函数 pcntl_wifstopped 检查子进程当前是否已经停止

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_wifstopped

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

pcntl_wifstopped检查子进程当前是否已经停止

说明

pcntl_wifstopped(int $status): bool

仅查子进程当前是否停止; 此函数只有作用于使用了WUNTRACED作为 option的pcntl_waitpid()函数调用产生的status时才有效。

参数

status

参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。

返回值

如果子进程当前是停止的返回 true ,其他情况返回 false

参见

阅读全文 »

PCNTL 函数 pcntl_wstopsig 返回导致子进程停止的信号

发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数

pcntl_wstopsig

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

pcntl_wstopsig返回导致子进程停止的信号

说明

pcntl_wstopsig(int $status): int

返回导致子进程停止的信号编号。这个函数仅在pcntl_wifstopped()返回 true 时有效。

参数

status

参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。

返回值

返回信号编号。

参见

阅读全文 »

PCNTL 函数 pcntl_fork 在当前进程当前位置产生分支(子进程)。译注:fork是创建了一个子进程,父进程和子进程 都从fork的位置开始向下继续执行,不同的是父进程执行过程中,得到的fork返回值为子进程 号,而子进程得到的是0。

发表日期:2021-07-01 08:56:15 | 来源: | 分类:PCNTL 函数

      示例1
<?php 
$pid = pcntl_fork();
//父进程和子进程都会执行下面代码
if ($pid == -1) {
//错误处理:创建子进程失败时返回-1.     
    die('could not fork');
}else if ($pid) {
//父进程会得到子进程号,所以这里是父进程执行的逻辑     
    pcntl_wait($status);
    //等待子进程中断,防止子进程成为僵尸进程。
}else{
    //子进程得到的$pid为0, 所以这里是子进程执行的逻辑。
}
?>

阅读全文 »

全部博文(1589)
集速网 copyRight © 2015-2025 宁ICP备15000399号-1 宁公网安备 64010402001209号
与其临渊羡鱼,不如退而结网
欢迎转载、分享、引用、推荐、收藏。