子进程打印错误ppid()

时间:2016-10-02 09:56:45

标签: c linux fork pid

在这个程序中,为什么子进程打印错误ppid()?

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>

void childprocess()
{
  printf("Child: Hi I am the child process\n");
  printf("Child: My process id is %d\n", getpid());
  printf("Child: My parent is %d\n", getppid());
  printf("Child: I am exiting\n");
}

void parentprocess()
{
   printf("Parent: Hi I am the parent process\n");
   printf("Parent: My process id is %d\n", getpid());
   printf("Parent: My parent is %d\n", getppid());
   printf("Parent: I am exiting\n");
}

int main()
{
    pid_t n = fork();
    if(n<0)
    {
      perror("fork failed:");
      exit(EXIT_FAILURE);
    }
    else if(n==0)
       childprocess();
    else
       parentprocess();
}

输出:

Parent: Hi I am the parent process
Parent: My process id is 21550
Parent: My parent is 7452
Parent: I am exiting
Child: Hi I am the child process
Child: My process id is 21551
Child: My parent is 1810
Child: I am exiting

如果我重新执行。有时输出是我期望的,有时是出乎意料的。

2 个答案:

答案 0 :(得分:2)

找到原因。那是愚蠢的。父级首先结束,因此子级(孤儿)正被init进程采用。

在我的情况下,它是进程ID为1810的Upstart。

  

Upstart是/ sbin / init

的基于事件的替代品

答案 1 :(得分:1)

实际上,无法保证调度程序将首先安排子进程。父进程可能在子进程运行之前终止。因为在Linux中,每个进程都有一个父进程(交换进程除外),孤立子进程被分配给init。

您可以添加dexOptions { incremental true javaMaxHeapSize "4g" } ,以便父进程等待子进程。