Linux进程间通信之FIFO

Linux进程间通信之FIFO

一、引言:FIFO有时被称为命名管道。未命名的管道只能在两个相关的进程之间使用,而且这两个相关的进程还要有一个共同的创建了它们的祖先进程,但是,通过FIFO,不相关的进程也能交换数据。它是一种文件类型,在文件系统中可以看到。程序中可以查看文件stat结构中st_mode成员的值来判断文件是否是FIFO文件。

二、 特点:
1.可在无关进程间交换数据(通信)。
2.FIFO有路径名与之相关联,它以一种特殊设备文件存在于文件系统中。

三、相关函数:
创建一个FIFO文件类似于创建文件,FIFO文件就像普通文件一样。

NAME
       mkfifo - make a FIFO special file (a named pipe)

SYNOPSIS
       #include <sys/types.h>
       #include <sys/stat.h>

       int mkfifo(const char *pathname, mode_t mode);
       //返回值:若成功,返回0;若失败,返回-1

其中mode的参数规格说明与open中的mode参数相同,一旦创建了FIFO,就可以用一般的文件I/O函数操作它。

当open一个FIFO时,非阻塞标志(O_NONBLOCK)会产生下列影响。
·在一般情况下(没有指定O_NONBLOCK),只读open要阻塞到某个其他进程为写而打开这个FIFO为止。类似地,只写open要阻塞到某个其他进程为读而打开它为止。
·如果指定了O_NONBLOCK,则只读open立即返回。但是,如果没有进程为读而打开一个FIFO,那么只写open将返回-1,并将errno设置成ENXIO。

命名管道的打开规则
(1)只读且阻塞方式
open(const char *pathname, O_RDONLY);
(2)只读且非阻塞方式
open(const char *pathname, O_RDONLY | O_NONBLOCK);
(3)只写且阻塞方式
open(const char *pathname, O_WRONLY);
(4)只写且非阻塞方式
open(const char *pathname, O_WRONLY | O_NONBLOCK);

实例1:创建一个FIFO
1.

#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <errno.h>
#include <fcntl.h>

int main()
{
   
        int ret = mkfifo("./file&#
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值