我试图在这里工作,我有一个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;
}


同样,您可以轻松地将两个管道用于两个方向。

10-07 14:24