我试图在这里工作,我有一个c程序,我的父进程在其中创建一个管道,以便他可以侦听子进程的请求。这些子项是动态创建的,永远不会是相同的数字。到目前为止,我设法通过管道将请求发送给父级,并使它通过互斥量同步。
我的问题是,此请求需要提供给提出此请求的孩子一个答案,并且我不能使用同一管道,因为它是一种方式,所有其他孩子都将使用它(我已经尝试过,并且会产生严重问题)
我尝试的下一件事是在子请求之前制作管道,并在请求中传递描述符的值。也失败了,因为父母不知道那些描述符,我在失败后才发现。
所以现在我对如何使请求响应到达孩子一无所知...
我是C编程的初学者,因此,欢迎所有帮助!
顺便说一句:在unix程序中工作,纯C编程
最佳答案
管道是单向的,使用套接字似乎对ipc有点痛苦。
我建议您使用socketpair()
。您可以将它们视为双向管道。
这是一个示例,其中父级向其子级发送一个字符,然后子级将其大写并将其发送回父级(来自beej的教程)
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#include <errno.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
int main(void)
{
int sv[2]; /* the pair of socket descriptors */
char buf; /* for data exchange between processes */
if (socketpair(AF_UNIX, SOCK_STREAM, 0, sv) == -1) {
perror("socketpair");
exit(1);
}
if (!fork()) { /* child */
read(sv[1], &buf, 1);
printf("child: read '%c'\n", buf);
buf = toupper(buf); /* make it uppercase */
write(sv[1], &buf, 1);
printf("child: sent '%c'\n", buf);
} else { /* parent */
write(sv[0], "b", 1);
printf("parent: sent 'b'\n");
read(sv[0], &buf, 1);
printf("parent: read '%c'\n", buf);
wait(NULL); /* wait for child to die */
}
return 0;
}
同样,您可以轻松地将两个管道用于两个方向。