gpt4 book ai didi

c - C 中的 Linux 管道

转载 作者:太空宇宙 更新时间:2023-11-04 10:16:13 28 4
gpt4 key购买 nike

我有以下代码:

#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/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com