阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

在Linux下创建FIFO文件类型

3次阅读
没有评论

共计 1150 个字符,预计需要花费 3 分钟才能阅读完成。

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

 

在 Linux 下创建 FIFO 文件类型

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

FIFO 和 pipe 的区别在于:

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

sh-3.2# ls -lhF。/fifo_file

100 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 的使用及其注意事项,在使用的时候需特别注意。

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-09-20发表,共计1150字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中