一个父进程的多个子进程

时间:2016-04-06 15:14:34

标签: c linux process fork

我正在使用fork实现一个简单的父/子进程程序。我的目标是从单个父级创建用户输入数量的子进程,并将其PID存储在动态数组中。我设法使用fork创建子进程(我认为)并存储他们的PIDS。但是,当我存储PID时,我还存储了0 PID以及我认为与进程相关的另一个PID,但这个数字比子进程和父进程大得多。

如果只在父进程内部完成,这怎么会发生?

void createProcesses(int nProcess) {
  int i;
  int PID;
  processIDS = calloc(nProcess, sizeof(long));

  printf("*****Creating Processes*****\n");

  printf("Parent Process: PID %d\n", getpid());
  for (i = 0; i < nProcess; i++) {
    PID = fork();
    if (PID == 0) {
      printf("Child Process: PID %d\n", getpid());
      while(1){}
    }
    else if(PID != 0) {
      // sleep(3);
      // printf("Number of child processes created: %d\n", nProcess);
      // updateProcessList();
      *(processIDS + i) = PID;
      printf("%d\n", PID);
    }
  }
  for(i = 0; i < sizeof(processIDS); i++) {
    printf("%ld\n", *(processIDS + i));
  }
  while(1) {
    sleep(5);
    updateProcessList();
  }
}

processIDS is a long * global variable.

1 个答案:

答案 0 :(得分:5)

问题在于:

  for(i = 0; i < sizeof(processIDS); i++) {
    printf("%ld\n", *(processIDS + i));
  }

因为processIDS是一个指针,它的大小是long *的大小,大概是4或8,这不是你想要的。如果nProcess的值小于此值,您将读取动态分配的数组的末尾,从而调用未定义的行为。

您知道已创建nProcess个进程,因此请将其用于循环测试:

  for(i = 0; i < nProcess; i++) {
    printf("%ld\n", *(processIDS + i));
  }