程序:
#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的输出保存在父级的数组中。有没有办法做到这一点。
答案 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()
。