有些孩子的过程会多次完成他们的工作

时间:2012-10-17 15:11:10

标签: c linux fork

我写了一个程序,为一个进程创建了3个子进程。 然后,每个孩子也会创建3个过程。

这是代码:

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <time.h>
#include <stdbool.h>
#define GENERACIONES 2

void crearHijo(int, int);

int main()
{
    int i;

    for (i = 1; i <= 3; i++)
        crearHijo(i, 1);

    return 0;
}

void crearHijo(int hijoNum, int gen)
{
    pid_t pid = fork();
    int i, hijos = 3;

    if (pid < 0)
    {
        fprintf(stderr, "Fork Failed");
        exit(-1);                       
    }
    else if (pid == 0)
    {
        printf("Soy de la generación %d, hijo # %d, PID: %d, PPID: %d\n",
                 gen, hijoNum, getpid(), getppid());

        if (gen < GENERACIONES)
        {
            gen++;
            /*srand(time(NULL));
            hijos = rand() % 3 + 1;*/

            for (i = 1; i <= hijos; i++)
                crearHijo(i, gen);
        }

        exit(0);
    }
    else
        waitpid(pid, NULL, NULL);
}

我期待着3个儿子和9个孙子。 但我得到以下输出:

Soy de la generación 1, hijo # 1, PID: 2533, PPID: 2532
Soy de la generación 2, hijo # 1, PID: 2534, PPID: 2533
Soy de la generación 1, hijo # 1, PID: 2533, PPID: 2532
Soy de la generación 2, hijo # 2, PID: 2535, PPID: 2533
Soy de la generación 1, hijo # 1, PID: 2533, PPID: 2532
Soy de la generación 2, hijo # 3, PID: 2536, PPID: 2533
Soy de la generación 1, hijo # 1, PID: 2533, PPID: 2532
Soy de la generación 1, hijo # 2, PID: 2537, PPID: 2532
Soy de la generación 2, hijo # 1, PID: 2538, PPID: 2537
Soy de la generación 1, hijo # 2, PID: 2537, PPID: 2532
Soy de la generación 2, hijo # 2, PID: 2539, PPID: 2537
Soy de la generación 1, hijo # 2, PID: 2537, PPID: 2532
Soy de la generación 2, hijo # 3, PID: 2540, PPID: 2537
Soy de la generación 1, hijo # 2, PID: 2537, PPID: 2532
Soy de la generación 1, hijo # 3, PID: 2541, PPID: 2532
Soy de la generación 2, hijo # 1, PID: 2542, PPID: 2541
Soy de la generación 1, hijo # 3, PID: 2541, PPID: 2532
Soy de la generación 2, hijo # 2, PID: 2543, PPID: 2541
Soy de la generación 1, hijo # 3, PID: 2541, PPID: 2532
Soy de la generación 2, hijo # 3, PID: 2544, PPID: 2541
Soy de la generación 1, hijo # 3, PID: 2541, PPID: 2532

有些条目是重复的,我不明白为什么。 不超过12个进程,但有些进程多次打印输出。 我该如何避免这种行为?

TIA

1 个答案:

答案 0 :(得分:3)

当你的:

waitpid(pid, NULL, NULL);

在子进程上完成,函数返回和主要的

for (i = 1; i <= 3; i++)

继续

尝试这样的事情:

    int main()
{
    int i;
    bool j = true;

    for (i = 1; i <= 3; i++)
    {
       if (j == true)
        j = crearHijo(i, 1);
    }

    return 0;
}

bool crearHijo(int hijoNum, int gen)
{
    pid_t pid = fork();
    int i, hijos = 3;

    if (pid < 0)
    {
        fprintf(stderr, "Fork Failed");
        exit(-1);                       
    }
    else if (pid == 0)
    {
        printf("Soy de la generación %d, hijo # %d, PID: %d, PPID: %d\n",
                 gen, hijoNum, getpid(), getppid());

        if (gen < GENERACIONES)
        {
            gen++;
            /*srand(time(NULL));
            hijos = rand() % 3 + 1;*/

            for (i = 1; i <= hijos; i++)
                crearHijo(i, gen);
        }

        exit(0);
    }
    else
    {
        waitpid(pid, NULL, NULL);
        return (false);
    }
 return (true);
}