进程间通信在实际项目中多多少少都会使用到,最常用的有无名管道,有名管道,消息队列,信号,信号量,共享内存等进程间的通信方式。网络通信套字节 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、有名管道