IPC 是 Linux 编程中一个重要的概念,IPC 有多种方式,本文主要介绍命名管道(FIFO),命名管道可以完成同一台计算机上的进程之间的通信,本文给出了多个具体的实例,每个实例均附有完整的源代码;本文所有实例在 Ubuntu 20.04 上编译测试通过,gcc版本号为:9.4.0;本文适合 Linux 编程的初学者阅读。
1 命名管道(FIFO)的基本概念
-
FIFO(First-In First-Out),在 Linux 文件系统中是一种特殊的文件,相对于匿名管道,FIFO 又被称为命名管道;
-
在我的另一篇文章《IPC之一:使用匿名管道进行父子进程间通信的例子》中,介绍了管道(又称匿名管道)的基本概念;
-
匿名管道和命名管道本质上是一种东西,在内核中都是一个
inode
,只是因为匿名管道在物理文件系统中没有文件故而仅能通过进程间的继承来传递这个inode
的索引号;而命名管道因为有了物理文件系统中的文件,通过这个文件可以找到内核中相应的inode
,故而对该文件有读写权限的进程均可以使用这个管道; -
命名管道的工作方式与匿名管道非常相似,但有一些明显的差异:
- 命名管道作为一种特殊文件存在于文件系统中,匿名管道仅存在于内核中,不存在于文件系统中;
- 不同祖先的进程可以通过命名管道