0

我尝试在 C 中实现一个管道,但我有一个小问题:

这是我的功能:

void commandeTube(char * c1, char * c2) {
    int c1toc2[2];
    int c2toPere[2];
    pid_t pidc1, pidc2;
    if(pipe(c1toc2) && pipe(c2toPere)) {
        perror("Erreur");
        errno=0;
        return ;
    }
    pidc2 = fork();
    if(pidc2 != 0) {
        pidc1=fork();
        if(pidc1!=0) {

            int status;
            waitpid(pidc1,&status,0);
            char buffer[1024]={0};
            int n;
            while((n=read(c2toPere[0],buffer,1024))==1024)
                write(1,buffer,n);
            write(1,buffer,n);


        }
        else if(pidc1==0){
            write(STDOUT_FILENO,"C1\n",3);
            /*On est dans C1*/
            close(c1toc2[0]);
            dup2(c1toc2[1],1);
            char * argc1[10];
            constructTab(c1,argc1);
            write(STDOUT_FILENO,"C1 exe\n",7);
            if(execvp(argc1[0],argc1)==-1) {
                perror("Erreur execlp");
                errno=0;
                return;
            }
            freeTab(argc1);
            write(STDOUT_FILENO,"C1 fin\n",7);
        } 

    }
    else {
            /*C2*/
            write(STDOUT_FILENO,"C2\n",3);
            int stat;
            char * argc2[10];
            constructTab(c2,argc2);
            close(c1toc2[1]);
            /*close(c2toPere[0]);*/
            dup2(c1toc2[0],STDIN_FILENO);
            /*dup2(c2toPere[1],1);*/
            write(STDOUT_FILENO,"C2 exe\n",7);
            if(execvp(argc2[0],argc2)==-1) {
                perror("Erreur execlp");
                errno=0;
                return;
            }
            freeTab(argc2);
            write(STDOUT_FILENO,"C2 fin\n",7);

    }
}

例如,如果我有这个:

cmd1 | 命令2

主进程创建 2 个子进程,一个为cmd1,另一个为cmd2。的输出cmd1被重定向到 的输入cmd2。我的问题是cmd2之前执行的cmd1,所以如果我输入:

ls | 厕所

例如,wc 将首先启动。这就是我在 shell 中看到的:

C2
C1
C2 exe

如何在执行 C2 之前完全执行 C1?早些时候,我试图让 c1 成为 c2 的孩子,waitpid(c1,...,..);但我得到了相同的结果。

4

2 回答 2

0

如果您希望将第一个命令的输出重定向到您可能考虑阅读的第二个命令的输入man 2 pipe,这里有一个很好的示例,它应该让您走上正轨。

http://linux.die.net/man/2/pipe

于 2013-05-02T18:20:00.613 回答
0

您的代码对我有用,但 C1 exe 消息被重定向到管道。我把所有的都改成了STDOUT_FILENOSTDERR_FILENO然后我看到了

C2
C1
C1 exe
C2 exe
    193     194    1502

使用 ls wc 运行时。

于 2013-05-02T20:25:43.803 回答