1.1、源码
在之前的代码根本上,修正得到如下代码
<?php
$name = 'xiaobei';
$pid = pcntl_fork();
if ($pid<0) {
}
if ($pid===0) {
echo \"大众I am a child.-->\"大众,posix_getppid(),'-->',posix_getpid(),'->',$name,PHP_EOL;
exit;
while (1) {
echo time(),PHP_EOL;
sleep(2);
}
}
echo \"大众I am a father-->\公众,posix_getpid(),'-->',$name,PHP_EOL;
1.2、实行结果
截图的关系,程序还是每隔1s,输出当前韶光。产生此结果的缘故原由是什么?
1.3、缘故原由解释
由于父进程先于子进程退出。因此子进程就成了孤儿进程。它被linux系统的1号进程收养,从而摆脱当前的运行终端。
那是否可以避免此种情形,或者说,当我们创建子进程后,一定要确保子进程完全退出后,父进程才退出
2、修正案例的源码2.1、源码
<?php
/
Copyright (C) Iamasb
@project : 3、workerman干系知识点
@explain : fork子进程
@filename : fork.php
@author : iamasb
/
$name = 'xiaobei';
$pid = pcntl_fork();
if ($pid<0) {
die(\"大众fork is error.\公众);
}
if ($pid===0) {
echo \"大众I am a child.-->\公众,posix_getppid(),'-->',posix_getpid(),'->',$name,PHP_EOL;
while (1) {
echo time(),PHP_EOL;
sleep(2);
}
}
echo \"大众I am a father-->\"大众,posix_getpid(),'-->',$name,PHP_EOL;
// 非壅塞的运行办法
//while (1) {
// $pid = pcntl_wait($status,WNOHANG); // 非壅塞
// if ($pid>0) {
// echo 'exit->',$pid,'-->',$status,PHP_EOL;
// exit;
// }
//}
$pid = pcntl_wait($status,WUNTRACED); // 壅塞,直到子进程退出时,才返回
echo 'exit->',$pid,'-->',$status,PHP_EOL;
2.2、实行结果
备注: 由于当前输出信息,霸占了终端。因此只能另开shell终端,并利用kill命令,杀去世子进程