分类: LINUX
2011-11-14 15:25:41
我的demo程序的思路是这样的,主进程fork两个子进程,第二个子进程延迟1s结束,主进程调用两个waitpid,先等待子进程2,再等待子进程1 。
测试结果,子进程2结束后第一个waitpid才会返回。
#include
#include
#include
int main()
{
pid_t pid;
int i;
int id[2];
for(i = 0; i < 2; ++i)
{
pid = fork();
if(pid == 0)
{
printf("child process!\n");
if(i == 1)
{
sleep(1);
printf("sleep 1\n");
}
exit(0);
}
else
{
printf("parent process!\n");
}
id[i] = pid;
}
for(i = 0; i < 2; ++i)
{
printf("child%d:%d\n", i, id[i]);
}
printf("first wait!\n");
pid = waitpid(id[1], NULL, 0);
printf("pid:%d\n", pid);
printf("second wait!\n");
pid = waitpid(id[0], NULL, 0);
printf("pid:%d\n", pid);
sleep(2);
printf("return!\n");
return 0;
}
运行结果:
parent process!