我正在开发一个使用execvp执行程序的程序。它需要捕获子进程的结果并在主进程中解析它们。似乎有一种方法,使用命名管道和重复。我试图找到一个很好的例子,但到目前为止还没有运气。如果有人对此有任何指示,链接和/或建议,我将非常感激。
答案 0 :(得分:6)
您不需要命名管道;未命名的管道工作得很好。实际上,您通常可以使用popen
而不是自己使用pipe
/ fork
/ dup
/ exec
。 popen
的工作方式如下(尽管您的libc
实施可能会有更多错误检查):
FILE *popen(const char *command, const char *type) {
int fds[2];
const char *argv[4] = {"/bin/sh", "-c", command};
pipe(fds);
if (fork() == 0) {
close(fds[0]);
dup2(type[0] == 'r' ? 0 : 1, fds[1]);
close(fds[1]);
execvp(argv[0], argv);
exit(-1);
}
close(fds[1]);
return fdopen(fds[0], type);
}
这将创建一个未命名的管道和fork
。在孩子中,它将stdout(或stdin)重新连接到管道的一端,然后exec
是孩子。父母可以简单地从管道的另一端读取(或写入)。
答案 1 :(得分:2)
你能不能只使用popen()?
答案 2 :(得分:0)
这是一个简单的例子,演示了使用popen实现目标。只需把比“echo”更有趣的东西作为命令:)
#include <stdio.h>
int main()
{
char buf[100];
int i = 0;
FILE *p = popen("echo \"Test\"","r");
if (p != NULL )
{
while (!feof(p) && (i < 99) )
{
fread(&buf[i++],1,1,p);
}
buf[i] = 0;
printf("%s",buf);
pclose(p);
return 0;
}
else
{
return -1;
}
}