我在子进程中执行此操作:execlp ("wc", "wc" ,filename,"-l", NULL)
并将管道中的输出重定向以从父进程读取。
一切正常,但当wc
选项找不到指定的文件名时,会导致无限循环。与find选项相同。
我如何检查execlp
的输出或我该怎么做才能进入这个无限循环?
这是使用fork创建的子代码:
close(1);
if (dup (pipeCom[1]) != 1)
{
fprintf (stderr, "dup - 1\n");
exit (1);
}
execlp ("wc", "wc" ,filename,"-l", NULL);`
这是来自父进程的代码:
wait();
if ((num = read(pipeCom[0],&out,200))==0)
perror("pipe error");
else {
out[num] = '\0';
}
printf("%s",out);
答案 0 :(得分:1)
Jonathan对dup2()和“-l”选项的位置绝对正确。 话虽如此,SSCCE会是这样的:
#include <sys/types.h>
#include <sys/wait.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char *argv[])
{
const char *filename = "/etc/passwd"; /* whatever */
int pipeCom[2];
char out[200];
int num, status;
if(pipe(pipeCom)) {
perror("pipe");
return 111;
}
if(argv[1])
filename = argv[1];
switch(fork()) {
case -1:
perror("fork");
return 111;
case 0:
/* child */
close(1);
if (dup (pipeCom[1]) != 1)
{
fprintf (stderr, "dup - 1\n");
exit (1);
}
execlp ("wc", "wc" ,filename,"-l", NULL); /* Jonathan! */
perror("wc");
return 111;
default:
/* parent */
wait(&status);
if ((num = read(pipeCom[0],&out,200))==0)
perror("pipe error");
else {
out[num] = '\0';
}
printf("%s",out);
break;
}
return 0;
}
由于没有参数的wait(),您的原始代码甚至无法编译;简单地修复导致编译并在我的系统上工作的程序,所以... 您是否可以发布完全那些给您带来麻烦的代码,解释完全如何编译/运行它以及完全什么是失败的?我的胆量告诉我,在你的情况下,filename == NULL,但如果是这样的话,那么在你的程序中读取它比想象它更好很多; p