unix环境编程 第十五章 15.5FIFO

FIFO有时被命名为管道。通过FIFO,不相关的进程也能交换数据。

创建FIFO类似于创建文件

#include <sys/stat.h>
int mkfifo(const char *path,mode_t mode);
int mkfifoat(int fd,const char *path,mode_t mode);
//成功返回0,出错返回-1

mode参数的规格说明与open函数中的mode的相同。

当open一个FIFO时,非阻塞标志会产生下列影响:

  • 在一般情况下,制度open阻塞到其他进程为写而打开这个FIFO为止。类似的,只写open要阻塞到某个其他进程为读而打开它为止。
  • 如果指定了O_NONBLOCK,则只读open立即返回。但是,如果没有进程为读而打开一个FIFO,那么只写open将返回-1,并将errno设置成ENXIO。

一个给定的FIFO有多个写进程时常见的,这就意味着,如果不希望多个进程所写的数据交叉,则必须考虑原子操作。

FIFO有以下两种用途:

  1. shell命令使用FIFO将数据从一条管道传送到另外一条管道的时候,无需创建中间临时文件。
  2. 客户进程-服务器进程应用程序中,FIF用作汇聚点,在客户进程和服务器进程二者之间传递数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值