在子进程中执行并发送到管道,结果导致无限循环

时间:2013-10-19 14:08:05

标签: c linux

我在子进程中执行此操作: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);

1 个答案:

答案 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