有名管道解决了无名管道只能在亲缘进程间通信的弊端
相较于无名管道只能用于亲缘关系进程之间的通信,有名管道可以再任意两个进程间实现通信,该管道可以通过路径名使用,并且在文件系统中是可见的(无名管道不可见)。
两个进程可以把FIFO当做普通文件一样进行读写操作。
也是先进先出,从开始处返回数据,再末尾进行添加数据。
不能使用lseek进行文件重定位。
使用步骤
- mkfifo创建管道
- open函数打开文件
- read/write进行读写通信。
int mkfifo(const char *filename, mode_t mode)
mode:
O_RDONLY 读
O_WRONLY 写
O_RDER 读写
O_NONBLOCK 非阻塞
O_CREAT 文件不存在进行创建
O_EXCEL 使用creat文件存在,返回错误消息,用于测试文件是否存在。
为了保证管道一定被创建,两个进程都进行创建,谁先运行就使用谁的,后运行的发现有管道直接打开。
O_NONBLOCK对于读写的影响
没有O_NONBLOCK
读会一直堵塞,直到管道有数据
写也会一直堵塞,直到有进程读
有O_NONBLOCK
读打开立即返回
没有进程读,而写打开文件造成err
没有进程打开读,在对其进行写产生信号SIGPIPE(无名管道也是)