重定向execl函数的结果

时间:2016-01-12 09:57:11

标签: c linux unix execl

程序:

#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
int main()
{
        int cpid=fork();
        if(cpid==0){
                execl("/bin/ls","ls","-lah","--color",NULL);
        }
        else{
                int status;
                waitpid(cpid,&status,0);
                if(status!=0)
                        printf("Error Occured\n");
        }
return 0;
}

输出:

$ ./a.out 
total 20K
drwxrwxr-x 1 guest guest 4.0K Jan 12 15:21 .
drwxrwxr-x 1 guest guest 4.0K Jan 12 15:21 ..
-rwxrwxr-x 1 guest guest 7.2K Jan 12 15:19 a.out
-rw-rw-r-- 1 guest guest  372 Jan 12 15:20 execl.c
$ 

在上面的程序中,parent创建一个子节点,子节点执行ls命令。但是,我的要求是将ls的输出保存在父级的数组中。有没有办法做到这一点。

2 个答案:

答案 0 :(得分:3)

exec*()系列函数用新的函数替换当前进程的图像。所以你不能直接阅读它。您不需要子进程来读取外部命令的输出。您可以使用popen()来实现这一目标。

如果你必须创建一个子进程,那么你可以使用pipe(2)从子进程的输出中读取。您可以在链接的手册页上找到一个简单的示例。

答案 1 :(得分:1)

使用popen()是一种可能性,但如果您想使用fork()/exec*(),则可以执行此操作:

fork()之前,创建一个管道并将其附加到子项目中的stdout

int fds[2];
pipe(fds);

在fork之后,在子进程中关闭读取的fd并将write fd附加到stdout:

close(fds[0]);
dup2(fds[1], 1);
close(fds[1]);

在父进程中,关闭write fd并从read-fd读取以获取输出:

close(fds[1]);
read(fds[0], buf, sizeof(buf));

如果您需要缓冲,可以在父进程中的read-fd上调用fdopen()