管道
什么是管道
管道是UNIX系统中最古老的IPC(进程间通信)方式,所有UNIX系统都提供这种通信机制。
管道就是从一个进程连接到另一个进程的一个数据流
局限性
- 为了可移植性,管道都采用历史沿用的半双工(数据只能单向流动)通信
- 管道只能在具有公共祖先的两个进程间使用
匿名管道
pipe
创建一个匿名管道
由参数返回两个文件描述符:fd[0] 为读端(从管道读)打开,fd[1]为写端(从管道写)打开(读写端与默认文件描述符相反)
管道示意图
由于单个进程中的管道几乎没有任何用处,所以通常进程会先调用pipe,接着调用fork,创建父进程到子进程的IPC管道,如图:
fork之后做什么取决于数据流方向(管道永远流向读端(关闭 fd[1] 的那端)):
- 父进程关闭读端 fd[0] 子进程关闭写端 fd[1] 管道流向从父进程到子进程
- 父进程关闭写端 fd[1] 子进程关闭读端 fd[0] 管道流向从子进程到父进程
- 读0写1,永远流向读,读关1,写关0。