服务器/客户端通过管道通信

时间:2012-06-05 09:26:40

标签: c client-server ipc communication pipe

我最近开始学习IPC,但我遇到了一些问题。我编写了一个程序,它创建了两个通过管道进行通信的进程:

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <sys/types.h>
#include <unistd.h>


int main(void)
{
    int pfds[2];
    char buf[30];
    pipe(pfds);
    if (!fork()) 
    {
        printf(" CHILD: writing to the pipe\n");
        write(pfds[1], "test", 5);
        printf(" CHILD: exiting\n");
        exit(0);
    } 
    else 
    {
        printf("PARENT: reading from pipe\n");
        read(pfds[0], buf, 5);
        printf("PARENT: read \"%s\"\n", buf);
        wait(NULL);
    }
    return 0;
}

很抱歉没有处理潜在的错误,为了简单起见,我这样写了。

这很好但我的问题是:是否有可能有两个程序 - 服务器/客户端(两个独立的可执行文件 - 不是父进程/子进程关系)通过管道进行通信?就像你可以通过FIFO一样?

谢谢!

1 个答案:

答案 0 :(得分:2)

常规管道只能连接两个相关进程。它由一个进程创建,并在最后一个进程关闭时消失。

要在两个单独的进程之间进行通信,您必须使用命名管道(FIFO)。