Linux下如何创建FIFO文件
本文小编为大家详细介绍“Linux下如何创建FIFO文件”,内容详细,步骤清晰,细节处理妥当,希望这篇“Linux下如何创建FIFO文件”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
FIFO文件即命名管道 ,通过命名管道可以在不相关的进程之间交换数据。FIFO有路径名与之相关联,以一种特殊设备文件形式存在于文件系统中。
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文件,
#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文件”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341