c - C 中的 Linux 管道

标签 c linux file pipe

我有以下代码:

#include<stdio.h>

FILE *f,*stream1,*stream2,*stream3,*stream4;

int main()
{
    int pfd[2];
    int pfd1[2];
    int pfd2[2];
    int pid1;
    int pid2;

    pipe(pfd);
    pipe(pfd1);
    pipe(pfd2);

    f=fopen("date","r");
    pid1=fork();


    if(pid1==0){

        close(pfd[1]);

        stream2=fdopen(pfd[0],"r");

        char c;
        int rd=fread(&c,sizeof(char),1,stream2);
        while(rd!=0){
            printf("%c",c);
            rd=fread(&c,sizeof(char),1,stream2);
        }
        close(pfd[0]);
        exit(0);

    }

    pid2=fork();

    if(pid2==0){

        printf("second process\n");
        exit(0);

    }
    if(pid1>0&&pid2>0){
        close(pfd[0]);
        stream1=fdopen(pfd[1],"w");
        while(!feof(f)){
            char c;
            fscanf(f,"%c",&c);
            if(feof(f)) break;
            fwrite(&c,sizeof(char),1,stream1);
        }
        close(pfd[1]);
        exit(0);
    }
}

此代码从文件中获取一些输入并将其显示在 child1 中。 问题是每当我想在父进程中关闭 pfd[1] 时,child1 (pid1) 中的输出不会显示。为什么会这样?如果我不关闭 pfd[1],它会正常运行。

编辑:我解决了。问题是我使用了 fread、fwrite 而不是读写。有了这个,一切都按我想要的方式运行。

最佳答案

有两个问题:

1) 您正在使用 fdopenfwrite 而不是使用 write 写入管道。

这是可能的,但是 fwrite 会在内部调用 write 之前缓冲数据。

当您调用 fclose(stream1) 时,fclose 函数将首先使用 write() 写入所有缓冲数据,然后调用 关闭(pfd[1])

但是,如果您直接调用 close(pfd[1]),则缓冲数据不会写入管道。

2) 当程序完成时,子进程通常也会被杀死。

在使用 fork 创建的所有子进程也完成之前,不要离开 main 函数。 (使用 returnexit() 都没有关系)。

使用waitpidwait4 函数等待子进程完成。

我在我的电脑上编译了这个程序:只有在解决两个问题时我才能得到想要的结果。

关于c - C 中的 Linux 管道,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46181803/

相关文章:

c - 如何正确创建 C 函数(包括头文件)

无法在 Windows 10 上编译 Cairo C 代码

c - 将全零分配给 C 中的嵌套结构(GCC 版本 < 5)

c++ - 尽管有 if 语句,Visual Studio 仍尝试包含 linux header

c++ - 如何从文件中读取 "uneven"矩阵,并存储到二维数组中?

php - php 扩展崩溃 - 将内存地址转换为行号

linux - 在 CentOS7 上公开 Docker Remote API v1.22

linux - 我以前从未设置过 cron 作业,但希望每天在我的服务器上运行一个 Python 脚本 15 分钟

c++ - 将文件读入字符串缓冲区并检测 EOF

java - 文件阅读器无法正常工作?