一、概念
1、基本概念
管道是一种最基本的IPC机制,作用于两个进程之间,完成数据传递;管道是Unix中最古老的进程间通信的形式。
2、管道的特点
(1)只能用于具有共同祖先的进程(具有亲缘关系的进程)之间通信;通常,一个管道由一个进程创建,然后该进程调用fork,此后,父子进程之间就可应用该管道
(2)管道的进程间通信是基于字节流的
(3)管道是基于文件形式的,自带同步互斥机制,并且只能进行单向传输
(4)一般而言,进程退出,管道释放,所以管道的生命周期是随进程的
二、管道的分类
1、匿名管道(pipe)
匿名管道用于实现具有亲缘关系的进程间通信,通常用于父子间进程
(1)匿名管道的创建函数
注释:调用pipe函数时,首先在内核中开辟一块缓冲区用于通信,它有一个读端和一个写端,然后通过pipefd参数传出给用户进程两个文件描述符,pipefd[0]指向管道的读端,pipefd[1]指向管道的写段。在用户层面看来,打开管道就是打开了一个文件,通过read()或者write()向文件内读写数据,读写数据的实质也就是往内核缓冲区读写数据。
返回值:成功返回0,失败返回-1。
(2)匿名管道实现
那么如何实现父子间进程呢?通常有以下步骤:
1. 父进程调用pipe函数创建管道,得到两个文件描述符fd[0]、fd[1]指向管道的读端和写端。
2. 父进程调用fork创建子进程,那么子进程也有两个文件描述符指向同一管道。
3. 父进程关闭管道读端,子进程关闭管道写端。父进程可以向管道中写入数据,子进程将管道中的数据读出。由于管道是利用环形队列实现的,数据从写端流入管道,从读端流出,这样就实现了进程间通信。