FIFO IPC机制是利用文件系统中的特殊文件来标识的。可以用mkfifo命令创建一个FIFO文件。
$ mkfifo tube
$ ls -l tube
ps:如果要使用函数创建,man 3 mkfifo获取更多信息。
FIFO文件在磁盘上没有数据块,仅用来标识内核中的一条通道,各进程可以打开这个文件进行read/write,实际上是在读写内核通道(根本原因在于这个file结构体所指向的read、write函数和常规文件不一样),这样就实现了进程间通信。
实现一个进程向有名管道里写,另一个进程从有名管道里读。代码演示如下:
readfifo.c
#include "./common/head.h"
/*功能:
*此进程负责从有名管道(tube文件)里读数据。
*/
int main()
{
int fd = open("./tube", O_RDONLY); //只读打开tube文件
perror("open tube r"); //如果不打开写程序,程序这行也不会打印,说明读程序阻塞在open函数这里
if(fd < 0){
perror("open tube r");
exit(1);
}
char buff[20] = {0};
ssize_t n = read(fd, buff, 20); //从tube管道读数据
write(STDOUT_FILENO, buff, n); //打印到终端
return 0;
}
$ gcc readfifo.c -o readfifo
writefifo.c
#include "./common/head.h"
/*功能:
*此进程负责向有名管道(tube文件)中写数据。
*/
int main()
{
int fd = open("./tube", O_WRONLY); //只写方式打开tube文件
perror("open tube w"); //如果读程序不打开,这一行也不会打印,说明阻塞在open函数
if(fd < 0){
perror("open tube w");
exit(1);
}
write(fd, "hello fifo\n", 11);
close(fd);
return 0;
}
$ gcc writefifo.c -o writefifo
结果:
复制两个终端,一个终端运行readfido,另一个终端运行writefifo。readfifo程序将内容读出并打印在终端上。
必须要两个程序都运行起来,否则单个程序就会阻塞在open函数位置。这和我们自己写的无名管道不同。一般来讲,必须有一个程序等着另一个程序,这笔买卖才做的成。