进程之间的通信指数据突破进程空间的隔离,完成数据在进程间传递。
管道
进程间的管道通信方式有两种形式,无名管道用于父子进程间,命名管道可以用在任意进程间。
无名管道
管道是单向的信道,进程从管道的写端口写入数据,需要数据从读端口中获取数据,数据在管道中按到达顺序流动。
下面展示一个父子进程用无名管道通信的例子:
pipe()用两个文字描述符来指代管道通信的读端和写端(fsn[]数组)。其中父进程关闭了管道的读端fds【0】并往管道的写端fds【1】写出信息,子进程关闭了管道的写端fds[1]并从管道的读端fds[0]读回信息。
命名管道:
前面提到的无名管道有一个主要缺点,只能通过父子进程之间(及其后代 )使用文件描述符的继承来访问,无法在任意的进程之间使用。命名管道 (named pipe)或者叫FIFO则突破了这个限制 。可以说FIFO就是无名管道的升级版—— 有可访问的磁盘索引节点,即FIFO文件将出现在目录树中(不像无名管道那样只存在于pipefs特殊文件系统中)。
在Linux中执行ipcs命令可以查看到当前系统中所有的System V IPC对象 ,如图所示。此时系统中还没有创建消息队列和信号量数组(或称信号量集&#x