C:等待兄弟进程终止

时间:2014-09-03 18:28:16

标签: c wait

我的程序必须创建n个孩子。收到信号后,会创建一个孩子。然后第一个孩子等待其他n-1个孩子。第二个等待其他n-2个孩子,依此类推,直到最后一个孩子跑完并立即完成。 我写这段代码,但它不起作用,我得到了侄子。

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>
#include <sys/wait.h>
void func(int sign)
{
    printf("received signal. I create a child\n");
}

int main(int argc, char*argv[])
{
    if(argc!=3)
    {
        printf("error\n");
        return 0;
    }
    int i,pid,status;
    int n=atoi(argv[1]);
    unsigned int m=(unsigned int)atoi(argv[2]);
    signal(SIGALRM,func);
    printf("i'm father: pid %d\n",getpid());
    for(i=0; i<n; i++)
    {
        alarm(m);
        pause();
        switch(pid=fork())
        {
        case -1:
            printf("error\n");
            break;
        case 0: 
            printf("i'm the hild numer %d, my pid is %d\n",i,getpid());
            if(i!=n-1)
            {
                wait(NULL);
                break;
            }
            else
            {
                printf("%d i have fnished\n",getpid());
                exit(0);
            }
            break;
        default:
            wait(NULL); 
            break;
        }
     }
     printf("finish\n");
     return 0;
}

1 个答案:

答案 0 :(得分:1)

您的代码的结构方式,您正在创建2^N进程。

您需要更改以下代码:

default:
   wait(NULL);
   break;

之后不再分叉的东西。一种方法是使用goto语句。这是一个更新版本。

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>
#include <sys/wait.h>

void func(int sign)
{
   printf("received signal. I create a child\n");
}

int main(int argc, char*argv[])
{
   if(argc!=3)
   {
      printf("error\n");
      return 0;
   }
   int i,pid,status;
   int n=atoi(argv[1]);
   unsigned int m=(unsigned int)atoi(argv[2]);
   signal(SIGALRM,func);
   printf("i'm father: pid %d\n",getpid());
   for(i=0; i<n; i++)
   {
      alarm(m);
      pause();
      switch(pid=fork())
      {
         case -1:
            printf("error\n");
            break;

         case 0:
            printf("i'm the child numer %d, my pid is %d\n",i,getpid());
            if(i!=n-1)
            {
               wait(NULL);
               break;
            }
            else
            {
               printf("%d i have fnished\n",getpid());
               exit(0);
            }
            break;

         default:
            wait(NULL);
            goto done;
      }
   }

done:
   printf("%d i have fnished\n",getpid());
   return 0;
}