管道
什么是管道
管道是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。
父进程通过管道读取子进程buf,并输出到stdout:

本文详细介绍了Linux系统中的管道通信机制,包括匿名管道和命名管道(FIFO)。阐述了管道的局限性,如半双工性质和只能在具有共同祖先的进程间使用。内容涵盖管道的创建、读写规则、原子性保证以及信号处理。同时,提到了协同进程的概念,并通过`mkfifo`命令讲解了如何创建命名管道,以实现不相关进程间的通信。
最低0.47元/天 解锁文章
1754

被折叠的 条评论
为什么被折叠?



