程序:
#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 Occuredn");
}
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
$
在上面的程序中,父级创建一个子级,子级执行ls命令。但是,我的要求是将ls的输出保存在parent中的数组中。有办法做到这一点吗。
exec*()
系列函数用新函数替换当前进程的映像。所以你不能直接读。您不需要子进程来读取外部命令的输出。您可以使用popen()
来实现这一点。
如果确实必须创建一个子进程,则可以使用pipe(2)
读取子进程的输出。您可以在链接的手册页上找到一个简单的示例。
使用popen()
是一种可能性,但如果你想使用fork()/exec*()
,你可以这样做:
在fork()
之前,创建一个管道并将其连接到子中的stdout
int fds[2];
pipe(fds);
在fork之后,在子进程中关闭读取fd并将写入fd附加到stdout:
close(fds[0]);
dup2(fds[1], 1);
close(fds[1]);
在父进程中,关闭写fd并从读fd读取以获得输出:
close(fds[1]);
read(fds[0], buf, sizeof(buf));
如果需要缓冲,可以在父进程的读取fd上调用fdopen()
。