
FIFO,又称作命名管道(named pipe),它是Linux系统中用于进程间通信的一种方法。
FIFO和pipe的区别在于:
FIFO在文件系统中有对应的inode,可以通过ls命令查看。
sh-3.2# ls -lhF 。/fifo_file100 prwxrwxrwx 1 root root 0 Jan 1 1970 。/fifo_file|sh-3.2#
正因为它有一个名字,所以任何进程都可以访问它,所以FIFO可用于任意两个进程之间的通信。
pipe没有名字,在现有文件系统中无法查看到它的存在。
它只能用于父子进程、兄弟进程等具有血缘关系的进程间通信。
创建FIFO的方法如下:
1. 调用umask系统调用来设定创建文件的权限,
#include 《sys/types.h》#include 《sys/stat/h》mode_t umask(mode_t mask);
2. 调用unlink系统调用先删除已经存在的fifo,
#include 《unistd.h》int unlink(const char *pathname);
3. 调用mkfifo库函数去创建一个FIFO文件,
时代网站信息管理系统SDCMS源码
时代网站信息管理系统SDCMS是一个以asp+access进行开发的门户网站系统。SDCMS门户版主要包含:文章、组图、视频、下载、单页、外链等模块,系统内置会员模型:会员组,VIP会员,积分购买,会员投稿,投票,评论,留言,心情,搜索,标签,头像组件,在线充值,支持QQ、新浪微博、支付宝等账户的一键登录登功能,是您快速建立类似A5,站长之家之类门户平台的良好选择。
155 查看详情
#include 《sys/types.h》#include 《sys/stat.h》int mkfifo(const char *pathname, mode_t mode);
或者可以通过调用mknod系统调用并且指定参数mode为S_IFIFO也可以创建一个FIFO文件,
#include 《sys/types.h》#include 《sys/stat.h》#include 《fcntl.h》#include 《unistd.h》int mknod(const char *pathname, mode_t mode, dev_t dev);
注意:
1. 使用FIFO进行通信,每次传输的数据要限定在PIPE_BUF之内;
2. 对于FIFO的访问就像访问正规文件(regular file)一样,可以使用open/read/write/close等系统调用进行访问。
使用FIFO的应用有:
1. 单纯的生产者/消费者问题,一个进程读数据,一个进程写数据;
2. 实现client/server架构的程序,客户端和服务器端通过FIFO进行通信。
上面就是Linux创建FIFO管道的方法介绍了,本文除了介绍了FIFO管道的创建外,还稍微介绍了下FIFO的使用及其注意事项,在使用的时候需特别注意。
以上就是在Linux下创建FIFO文件类型的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/940223.html
微信扫一扫
支付宝扫一扫