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



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

pipes
pipes.c
pipes.c~

父程序做的事情与shell相同,它运行命令"ls -al | 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 FAILEDnn");
              exit(3);
        }else if(child2 > 0){ //PARENT
//CHILD1 PROCESS
              child1 = fork(); //CREATING CHILD1
        if(child1 <0){//FORK FAIL
              fprintf(stderr, "CHILD1 FORK FAILEDnn");
              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;
}

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

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

正确的方法是

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

最新更新