linux+fifo+函数,Linux创建FIFO的方法

FIFO管道是一种文件类型,在Linux上创建FIFO非常容易,FIFO文件固有管道的特性,但和pipe管道有一定的区别,下面小编将针对FIFO管道的创建和使用做个详细介绍,以便你有个详细的了解。

2183740f3cb0cc646fbe3b3d61c39ee9.png

FIFO,又称作命名管道(namedpipe),它是Linux系统中用于进程间通信的一种方法。

FIFO和pipe的区别在于:

FIFO在文件系统中有对应的inode,可以通过ls命令查看。

sh-3.2#ls-lhF。/fifo_file

100prwxrwxrwx1rootroot0Jan11970。/fifo_file|

sh-3.2#

正因为它有一个名字,所以任何进程都可以访问它,所以FIFO可用于任意两个进程之间的通信。

pipe没有名字,在现有文件系统中无法查看到它的存在。

它只能用于父子进程、兄弟进程等具有血缘关系的进程间通信。

创建FIFO的方法如下:

1.调用umask系统调用来设定创建文件的权限,

#include《sys/types.h》

#include《sys/stat/h》

mode_tumask(mode_tmask);

2.调用unlink系统调用先删除已经存在的fifo,

#include《unistd.h》

intunlink(constcharpathname);

3.调用mkfifo库函数去创建一个FIFO文件,

#include《sys/types.h》

#include《sys/stat.h》

intmkfifo(constcharpathname,mode_tmode);

或者可以通过调用mknod系统调用并且指定参数mode为S_IFIFO也可以创建一个FIFO文件,

#include《sys/types.h》

#include《sys/stat.h》

#include《fcntl.h》

#include《unistd.h》

intmknod(constcharpathname,mode_tmode,dev_tdev);

注意:

1.使用FIFO进行通信,每次传输的数据要限定在PIPE_BUF之内;

2.对于FIFO的访问就像访问正规文件(regularfile)一样,可以使用open/read/write/close等系统调用进行访问。

使用FIFO的应用有:

1.单纯的生产者/消费者问题,一个进程读数据,一个进程写数据;

2.实现client/server架构的程序,客户端和服务器端通过FIFO进行通信。

上面就是Linux创建FIFO管道的方法介绍了,本文除了介绍了FIFO管道的创建外,还稍微介绍了下FIFO的使用及其注意事项,在使用的时候需特别注意。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值