#include<stdio.h>
int main()
{
int pid = fork();
int one[2];
int two[2];
int fp=pipe(one);
int sp=pipe(two);
int i;
char *c1,*c2,a1[8],a2[8];
c1="doggy";
c2="wangwang";
if(fp<0||sp<0)
perror("pipe failed\n");
if (pid == 0)
{
close(one[1]);
close(two[0]);
for (i = 0; i < 5; i++)
{
read(one[0],a1,10);
printf("%d. %s\n", i + 1,c1);
write(two[1],c2,10);
}
}
else
{
close(one[0]);
close(two[1]);
for (i = 0; i < 5; i++)
{
printf("%d. %s\n", i + 1,c2);
write(one[1],c1,8);
read(two[0],a2,8);
}
wait(NULL);
}
}
我想通过管道同步父进程和子进程。但在这段代码中,在gdb中,我总是接收信号SIGPIPE,然后管道断开。为什么?
密码怎么了?
最佳答案
你得在叉子前把管子安装好。fork()将克隆内存,因此如果随后设置管道,则不会有一个管道连接到两个实例,而是有两个未连接的管道。此外,如果你有两个管道,并从中读写,那是很危险的。这可能会导致死锁,所以请小心(在您的示例中,我认为可以)。
关于c - 为什么我的进程总是收到信号SIGPIPE,然后管道中断。我在gdb中看到了,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/28400932/