Unix-关于linux父子进程通信
1 #include<stdio.h>
2 #include<unistd.h>
3 #include<stdlib.h>
4
5 int main()
6 {
7 int n;
8 pid_t pid;
9 int fd[2];
10 char line[56];
11 if(pipe(fd) < 0)
12 {
13 printf("pipe errorn");
14 }
15 if((pid = fork()) > 0){
16 close(fd[1]);
17 n = read(fd[0],line,56);
18 if(n > 0){
19 printf("%sn",line);
20 }
21 }else if(pid == 0){
22 dup2(fd[1],1);
23 close(fd[1]);
24 close(fd[0]);
25 int x = 20;
26 while(x){
27 printf("hello worldn");
28 x--;
29 sleep(1);
30 }
31 return 0;
32 }
33 return 0;
34 }
35
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
1.你不去掉x--后,子进程循环完后就会退出,输出就会被发送到父进程,之所以会这样因为stdout 是由c 库实现的,输出一般会经过缓冲,子进程退出或必要时会被刷新到父进程。
2.解决方法:
a.printf 后调用fflush(stdout) 强制刷新。
b.不要重定向。fd[1] 到printf,直接使用write(fd[1],test,sizeof(test)) 发送。