进程通信之命名管道(FIFO)

1. FIFO

FIFO也被称为命名管道。管道只能由相关进程使用,这些相关进程的共同的祖先进程创建了管道。创建FIFO类似于创建文件。确实,FIFO的路径名存在于文件系统中。

#include <sys/stat.h>

int mkfifo(const char *pathname, mode_t mode);

mkfifo函数中mode参数的规格说明与open函数的mode相同。新FIFO的用户和组的所有权规则与新文件的规则相同(新文件的用户ID设置为进程的有效用户ID)。

一旦已经用mkfifo创建了一个FIFO,就可用open打开它。其实,一般的文件I/O函数(close,read,write,unlink等)都可用于FIFO。

当打开一个FIFO时,非阻塞标志(O_NONBLOCK)产生下列影响:

1).一般情况下(没有指定O_NONBLOCK),只读open要阻塞到某个其他进程为写而贷款此FIFO。类似的,只写open要阻塞到某个其他进程为读而打开它。

2). 如果指定O_NONBLOCK,则只读open立即返回。但是,如果没有进程已经为读而打开一个FIFO,那么只写open将出错返回-1,则errno置为ENXIO。

FIFO有两种用途:

1). FIFO由shell命令使用以便将数据从一条管道线传输另一条,为此无需创建中间临时文件。

2). FIFO用户客户进程-服务器进程应用程序中,以在客户进程和服务器进程之间传递数据。

 

 

 

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值