发布时间:2025-12-09 22:23:54 浏览次数:3
我们上篇博客里谈到,进程间通信的本质在于如何让两个进程看到同一份资源。匿名管道的核心思想就是让子进程继承父进程,从而让父子进程看到同一份管道文件,但这也使通信仅仅局限在具有血缘关系的进程之间。
而命名管道的处理办法就比较直截了当了:在指定路径下创建FIFO管道文件。多个进程就像使用普通文件一样对同一份管道文件进行读写操作,由此实现进程间通信。虽然命名管道挂靠于文件系统,但是内核在传递数据的时候会和磁盘去关联,写入时向内存中写入,读取时也从内存中读取,这和匿名管道是一致的
[返回值]: 创建成功返回0,失败返回-1
[使用总结]:
[demo]:
1.Comm.hpp文件
2.ServiceFifo文件
#include "Comm.hpp"int main(){CreateFifo();int fd = open(FIFO_PATH, O_RDONLY);while(true){char buff[15] = {0};ssize_t ss = read(fd, buff, sizeof(buff));buff[ss] = '\0';cout << buff << endl;}}3.ClientFIFO.cc文件
#include "Comm.hpp"int main(){int fd = open(FIFO_PATH, O_WRONLY);int cnt = 0;while(true){char msg[15] = "hello world";write(fd, msg, sizeof(msg));sleep(1);}return 0;}