0

从 C 中的父进程,我正在运行 3 个子进程,每个子进程都执行一个程序。

  • 程序 1 获取标准输入(用户输入)并将其打印到标准输出。
  • 程序 2 获取标准输入(应该来自程序 1),对其进行修改并打印到标准输出。
  • 程序 3 获取标准输入(应该来自程序 2),修改它并打印到标准输出

我得到程序 3 的输出,但程序 2 的修改没有显示。

以下是父级的相关代码:

if((child1 = fork()) < 0){
    /*fatal*/
}
else if(child1 == 0){ //inside child 1
    dup2(pipe1[1], 1); //child 1 uses pipe1[1] for writing
    close(pipe1[0]);

    execl("program1.out", (char *)0);
}
else{
    if((child2 = fork()) <0){
        /*fatal*/
    }
    else if(child2 == 0){ //inside child 2
        close(pipe1[1]);
        dup2(pipe1[0], 0); //child2 uses pipe1[0] for reading
        dup2(pipe2[1], 1); //child2 uses pipe[1] for writing

        execl("program2.out", (char *)0);
    }
    else{
        if((child3 = fork()) <0){
            /*fatal*/
        }
        else if(child3 == 0){ //inside child 3
            close(pipe2[1]);
            close(pipe1[0]);

            execl("program3.out", (char *)0);
        }
        else{ //inside parent
            wait(NULL);
        }
    }   
}

这些程序使用 fgets 和 printf 进行读/写。

我检查了以前的问题,但我无法找出我做错了什么。有任何想法吗?

4

1 回答 1

1

Child3需要做:

dup2(pipe2[0], 0); // child3 uses pipe2[0] for reading

您还需要关闭每个孩子不使用的所有管道。所以 child1 需要:

close(pipe2[0]);
close(pipe2[1]);

child2 需要:

close(pipe2[0]);

child3 需要:

close(pipe1[0]);
close(pipe1[1]);
close(pipe2[1]);

并且父母需要在分叉所有孩子之后关闭所有管道。

所有这些关闭都是必需的,以便EOF当管道中的前一个程序关闭管道时进程将读取,因为在所有打开它的进程关闭它之前,管道并没有真正关闭。

于 2014-06-03T09:01:34.657 回答