waitpid
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc,char *argv[])
{
pid_t pid = 0;
pid = fork();
if(pid < 0)
{
printf("fork failed\n");
return 1;
}
if(pid == 0)
{
sleep(5);
printf("child :%d",getpid());
printf(" \t %d",getppid());
}
else
{ //pid_t waitpid(pid_t pid,int * status,int options);
//子进程的结束状态值会由参数 status 返回,而子进程的进程识别码也会一起返回
while(pid != waitpid(pid,NULL,WNOHANG))//会暂时停止目前进程的执行,直到有信号来到或子进程结束。
//WNOHANG 若pid指定的子进程没有结束,则waitpid()函数返回0,不予以等待。若结束,则返回该子进程的ID
{
sleep(1);
}
printf("%d process had exited\n",pid);
}
return 0;
}
相关阅读
#include <sys/types.h> /* 提供类型pid_t的定义 */#include <sys/wait.h>pid_t wait(int *status)进程一旦调用了wait,就立即阻塞
一次偶然的测试中,发现su程序的BUG后,着手排查问题出自哪。 首先是简化代码作为测试。 int main(int argc, char *const argv[])
首先我们来了解一下所谓的僵尸进程,僵尸进程就是两个进程,一个父进程,一个子进程,其子进程终止后,0-3G的用户内存被回收,而3-4G的部分内