Linux C - 子进程认为管道是空的

时间:2017-04-01 17:45:50

标签: c linux fork

这个家庭作业有问题。我正在学习Linux C所以我是初学者。

现在练习很简单:我必须创建一个子进程。现在父进程需要读取文本文件(例如a.txt)并通过管道发送。子进程从管道读取并将管道内容打印到终端。但是我不明白子进程没有读取管道,因为它认为管道是空的。

我发布了迄今为止我所做的代码:

#include "myinclude.h" //a separate file which contains all needed headers to run the program.

#define MERET 80

int main(int argc,char *argv[]){

    int pfd[2];
    int status;
    char buffer[MERET];
    pid_t pid;
    FILE *fp1,*fp2;
    if(argc != 2){
        printf("Nincs eleg argumentum");
    }
    if(pipe(pfd) < 0){
        syserr("pipe");
    }
    if((pid = fork()) < 0){
        syserr("fork");
    }
    if(pid == 0){
        close(pfd[1]);
        if ((fp1 = fdopen (pfd[0],"r")) <0){
                    syserr("fdopen");
            }
        printf("mukodsz");
        while(fgets(buffer,MERET,fp1) != NULL){//something here is not good 
            printf("%s",buffer);
            fprintf(stdout,"Siker");
        }
        close(pfd[0]);
        exit(0);
    }
    close(pfd[0]);
    if ((fp1 = fdopen (pfd[1],"w")) == NULL){
        syserr("fdopen");
    }
    if((fp2 = fopen(argv[1],"r")) < 0){
        syserr("fopen");
    }
    while(fgets(buffer,MERET,fp2) != NULL){
        fprintf(fp1,"%s",buffer);
        //fprintf(stdout,"Siker\n");
    }
    close(pfd[1]);
    wait(&status);
    //fprintf(stdout,"Siker");
    exit(0);
}

在我的语言中,“siker”意味着成功。我用它来调试程序但是子进程的循环没有打印任何东西。

1 个答案:

答案 0 :(得分:1)

当你fdopen时。你必须fclose

如果您close改为原始文件描述符,则与FILE*关联的缓冲区中所有尚未写入的数据都会丢失。