使用fork()和pipe()的子Fork进程

时间:2014-05-29 22:46:16

标签: c linux fork pipe

我必须创建一个使用fork()创建两个子进程的管道。子1将stdout重定向到管道的写端,然后用execlp()执行" ls -al"命令。子2将其输入从stdin重定向到管道的读取端,然后执行" sort -n -k 5"命令。创建两个子进程后,父进程等待它们终止,然后才能退出。当我运行我的代码时,它提供以下输出:

pipes
pipes.c
pipes.c~

父程序与运行命令" ls -al |的shell完全相同sort -r -n -k 5"。当我从命令行执行此操作时,我得到以下内容:

-rwxrwxr-x 1 username username 8910 May 28 21:52 pipes
drwxrwxr-x 3 username username 4096 May 28 13:52 ..
drwxrwxr-x 2 username username 4096 May 28 21:52 .
-rwxrwxr-x 1 username username 1186 May 28 21:52 pipes.c
-rwxrwxr-x 1 username username 1186 May 28 19:48 pipes.c~

我的代码中有什么东西我没能正确获取输出吗?有什么提示吗?

我的代码:

#include <stdio.h>
#include <string.h>   // for strlen
#include <stdlib.h>   // for exit
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>


int main() {
    int pipes[2];
    pid_t child1, child2;


//PIPE

        int p = pipe(pipes);
        if (p<0){   //PIPE FAILS
             fprintf(stderr, "PIPE FAIL");
             exit(2);
        }

//CHILD2 PROCESS
              child2 = fork(); //CREATING CHILD2
        if(child2 < 0){//FORK FAIL
              fprintf(stderr, "CHILD2 FORK FAILED\n\n");
              exit(3);
        }else if(child2 > 0){ //PARENT

//CHILD1 PROCESS
              child1 = fork(); //CREATING CHILD1
        if(child1 <0){//FORK FAIL
              fprintf(stderr, "CHILD1 FORK FAILED\n\n");
              exit(4);
        }else if(child1 ==0){//CHILD1 P
              dup2(pipes[1], 1);
              close(pipes[0]);
              execlp("ls","-al",NULL);
        }
              wait(NULL);//PARENT WAITS
        }
         else if(child2 ==0){ //CHILD2
              dup2(pipes[0],0);
              close(pipes[1]);

              execlp("sort", "-r", "-n", "-k" , "5", NULL);
        }

    return 0;
}

1 个答案:

答案 0 :(得分:1)

exec和朋友希望您提供新计划argv向量的所有参数。请记住,按惯例,argv[0]是程序的名称,命令行参数从argv[1]开始。

但是你没有提供argv[0]参数,所以例如ls认为它是通过一个名为-al的符号链接调用的,并没有给出任何参数。

正确的方法是

execlp("ls", "ls", "-al", NULL);