进程间通信IPC——管道(1)

管道介绍:

在计算机编程中,IPC(Inter-Process Communication,进程间通信)是指不同进程之间进行数据交换和通信的机制。而管道(Pipe)是一种常用的IPC机制之一。

管道是一种特殊的文件,它提供了一个单向的数据流通道,允许一个进程将数据写入管道,另一个进程则可以从管道中读取数据。这样,两个进程之间就可以通过管道进行数据的传输和共享。

在Unix和类Unix系统中,管道可以通过调用pipe()函数来创建。管道有两个端口,分别称为读端(read end)和写端(write end)。一个进程可以将数据写入管道的写端,而另一个进程则可以从管道的读端读取这些数据。管道提供了一个先进先出(FIFO)的数据传输机制,确保写入管道的数据按照顺序被读取。

使用管道可以实现进程间的数据传输和通信,典型的应用场景包括父子进程之间的通信、管道连接多个进程形成管道链等。管道在操作系统和网络编程中广泛应用,它简单、高效,并且可以方便地实现进程间的数据共享。

管道(Pipe)在进程间通信中具有以下特征:

  • 伪文件
  • 管道中的数据只能一次读取
  • 数据在管道中,只能单向流动。

局限性:

  • 数据不能进程自己写,自己读。
  • 管道中数据不可反复读取,一旦读走,管道中不再存在。
  • 采用半双工通信方式,数据只能在单方向上流动。
  • 血缘关系进程间可用

尽管管道具有一些限制,但在某些场景下,它仍然是一种简单而有效的进程间通信方式,特别是对于父子进程之间的通信需求。

原理:内核使用环形队列机制,借助内核缓冲区(4k)实现。

管道用法:

int pipe(int pipefd[2]) 是一个系统调用函数,用于创建一个管道,并将管道的读写端文件描述符存储在 pipefd 数组中。

参数 pipefd 是一个长度为2的整数数组,用于存储管道的文件描述符。pipefd[0] 表示管道的读端文件描述符,pipefd[1] 表示管道的写端文件描述符。

函数返回值为整数类型,表示操作的成功与否。若返回值为0,则表示成功创建了管道;若返回值为-1,则表示创建管道失败,可能是由于系统资源不足或其他错误原因。

使用 pipe() 函数创建管道后,可以通过读端文件描述符从管道中读取数据,通过写端文件描述符将数据写入管道。这样,就可以实现进程间的通信和数据传输。

管道创建成功以后,创建该管道的进程(父进程)同时掌握着管道的读端和写端。如何实现父子进程间通信呢?
通常可以采用如下步骤:

 

1. 父进程调用 pipe 函数创建管道,得到两个文件描述符 fd[0] fd[1] 指向管道的读端和写端。
2. 父进程调用 fork 创建子进程,那么子进程也有两个文件描述符指向同一管道。
3. 父进程关闭管道读端,子进程关闭管道写端。父进程可以向管道中写入数据,子进程将管道中的数据读出。
由于管道是利用环形队列实现的,数据从写端流入管道,从读端流出,这样就实现了进程间通信。

代码案例:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <errno.h>
#include <pthread.h>

void sys_err(const char* str)
{
    perror(str);
    exit(1);
}

int main(int argc, char* argv[])
{
    int ret;
    int fd[2];
    pid_t pid;

    char *str="hello pipe\n";
    char buf[1024];

    ret=pipe(fd);
    if (ret==-1)
        sys_err("pipe error");

    pid=fork();
    if(pid>0){
        close(fd[0]);//close read fd
        write(fd[1],str,strlen(str));
        close(fd[1]);
    }
    else if(pid==0){
        close(fd[1]);
        ret = read(fd[0],buf,sizeof(buf));
        write(STDOUT_FILENO,buf,ret);
        close(fd[0]);
    }
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值