进程间通信在实际项目中多多少少都会使用到,最常用的有无名管道,有名管道,消息队列,信号,信号量,共享内存等进程间的通信方式。网络通信套字节 socket的方式也可以归为进程通行。
无名管道只能用于有亲缘进程之间的通信,有名管道可以实现无亲缘关系的通信。有名管道 fifo 给文件系统提供一个路径,这个路径和管道关联,只要知道这个管道路径,就可以进行文件访问,fifo 是指先进先出,也就是先写入的数据,先读出来。
有名管道:应用于两个进程之间数据的单向传递。在文件目录树上有一个文件标示(管道文件),实际不占磁盘空间,数据缓存在内存中。
有名管道
1、查看命令:man 3 mkfifo
2、头文件:
#include <sys/types.h>
#include <sys/stat.h>
3、函数原型:int mkfifo(const char *pathname, mode_t mode);
a、*pathname:有名管道的名字 例如:/home/gec/myfifo
b、 mode:八进制的权限, 例如:0777
4、返回值:
成功:0
失败-1
5、函数特点:
有名管道存在于文件系统中,提供写入原子性特征,共享内存效率高
6、有名管道的特征:
a、有名字,储存于普通文件系统中
b、任何具有相应权限的进程都可以使用open()来获取FIFO的文件描述符
c、跟普通文件一样,用read()和writ()来读和写
d、不能用lseek来定位
e、具有写入原子性,支持多写者同时进行写操作而数据不会相互践踏
下面来写一个例子简单使用管道通信。
写一个maina.c(进程A),一个mainb.c(进程B),一个管道文件fifo。A将hello写入管道中,B将hello读取并打印出来。
进程A:
进程B:
只运行A,A进程会阻塞运行,程序不会结束:
再运行B时,A才会运行结束。
反之,先运行B,B会阻塞,再运行A时,B才能解除阻塞。