PCNTL 函数 业 ,精于勤 荒于嬉.
- PCNTL 函数 pcntl_alarm 为进程设置一个alarm闹钟信号
-
发表日期:2021-07-01 08:56:15 | 来源: | 分类:PCNTL 函数
-
pcntl_alarm
(PHP 4 >= 4.3.0, PHP 5, PHP 7, PHP 8)
pcntl_alarm — 为进程设置一个alarm闹钟信号
说明
pcntl_alarm(int$seconds
): int创建一个计时器,在指定的秒数后向进程发送一个
SIGALRM
信号。每次对 pcntl_alarm()的调用都会取消之前设置的alarm信号。参数
-
seconds
-
等待的秒数。如果
seconds
设置为0,将不会创建alarm信号。
返回值
返回上次alarm调度(离alarm信号发送)剩余的秒数,或者之前没有alarm调度(译注:或者之前调度已完成) 时返回
0
。 -
- PCNTL 函数 pcntl_async_signals Enable/disable asynchronous signal handling or return the old setting
-
发表日期:2021-07-01 08:56:15 | 来源: | 分类:PCNTL 函数
-
pcntl_async_signals
(PHP 7 >= 7.1.0, PHP 8)
pcntl_async_signals — Enable/disable asynchronous signal handling or return the old setting
说明
pcntl_async_signals(bool$on
=null
): boolIf the
on
parameter is omitted, pcntl_async_signals() returns whether asynchronous signal handling is enabled. Otherwise, asynchronous signal handling is enabled or disabled.参数
-
on
-
Whether asynchronous signal handling should be enabled.
返回值
When used as getter (that is without the optional parameter) it returns whether asynchronous signal handling is enabled. When used as setter (that is with the optional parameter given), it returns whether asynchronous signal handling was enabled before the function call.
参见
- declare
-
- PCNTL 函数 pcntl_errno 别名 pcntl_get_last_error()
-
发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数
-
说明
此函数是该函数的别名: pcntl_get_last_error()
- PCNTL 函数 pcntl_exec 在当前进程空间执行指定程序
-
发表日期:2021-07-01 08:56:15 | 来源: | 分类:PCNTL 函数
-
pcntl_exec
(PHP 4 >= 4.2.0, PHP 5, PHP 7, PHP 8)
pcntl_exec — 在当前进程空间执行指定程序
说明
pcntl_exec(string$path
, array$args
= ?, array$envs
= ?): void以给定参数执行程序。
参数
-
path
-
path
必须时可执行二进制文件路径或一个在文件第一行指定了 一个可执行文件路径标头的脚本(比如文件第一行是#!/usr/local/bin/perl的perl脚本)。 更多的信息请查看您系统的execve(2)手册。 -
args
-
args
是一个要传递给程序的参数的字符串数组。 -
envs
-
envs
是一个要传递给程序作为环境变量的字符串数组。这个数组是 key => value格式的,key代表要传递的环境变量的名称,value代表该环境变量值。
返回值
当发生错误时返回
false
,没有错误时没有返回。 -
- 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, 所以这里是子进程执行的逻辑。 } ?>
- 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_error — Retrieve 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_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): intpcntl_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): boolpcntl_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_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_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_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() 的行为一致,不同在于它多了两个增强参数
seconds
和nanoseconds
,这使得脚本等待的事件有了一个时间的上限。参数
-
set
-
要等待的信号列表数组。
-
siginfo
-
siginfo
是一个输出参数,用来返回信号的信息。更详细情况参见 pcntl_sigwaitinfo()。 -
seconds
-
超时秒数。
-
nanoseconds
-
超时纳秒数。
返回值
成功时,函数pcntl_sigtimedwait()返回信号编号。
-
- 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_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_strerror — Retrieve the system error message associated with the given errno
说明
pcntl_strerror(int$errno
): string|false警告本函数还未编写文档,仅有参数列表。
参数
-
errno
-
返回值
Returns error description on success 或者在失败时返回
false
.参见
- pcntl_get_last_error() - Retrieve the error number set by the last pcntl function which failed
-
- 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
= ?): 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 或者以下两个常量或两个常量“或运算”结果(即两个常量代表意义都有效)。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_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_wexitstatus 返回一个中断的子进程的返回代码
-
发表日期:2021-07-01 08:56:16 | 来源: | 分类:PCNTL 函数
-
pcntl_wexitstatus
(PHP 4 >= 4.1.0, PHP 5, PHP 7, PHP 8)
pcntl_wexitstatus — 返回一个中断的子进程的返回代码
返回值
返回整形的子进程返回代码。
- 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检查子进程状态代码是否代表正常退出。
返回值
当子进程状态代码代表正常退出时返回
true
,其他情况返回false
。
- 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检查子进程是否是由于某个未捕获的信号退出的。
返回值
如果子进程是由于某个未捕获的信号退出的返回
true
,其他情况返回false
。
- PHP杂项(34)
- PHP基础-李炎恢系列课程(20)
- 中文函数手册(0)
- 错误处理 函数(13)
- OPcache 函数(6)
- PHP 选项/信息 函数(54)
- Zip 函数(10)
- Hash 函数(15)
- OpenSSL 函数(63)
- Date/Time 函数(51)
- 目录函数(9)
- Fileinfo 函数(6)
- iconv 函数(11)
- 文件系统函数(81)
- 多字节字符串 函数(57)
- GD 和图像处理 函数(114)
- 可交换图像信息(5)
- Math 函数(50)
- 程序执行函数(11)
- PCNTL 函数(23)
- JSON 函数(4)
- SPL 函数(15)
- URL 函数(10)
- cURL 函数(32)
- 网络 函数(33)
- FTP 函数(36)
- Session 函数(23)
- PCRE 函数(11)
- PCRE 正则语法(19)
- 数组 函数(81)
- 类/对象 函数(18)
- 函数处理 函数(13)
- 变量处理 函数(37)
- SimpleXML 函数(3)
- 杂项 函数(31)
- 字符串 函数(101)