新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > 进程间通信之:管道

进程间通信之:管道

作者:时间:2013-09-13来源:网络收藏

本文引用地址:http://www.eepw.com.cn/article/257127.htm

8.2.5FIFO

1.有名说明

前面介绍的是无名,它只能用于具有亲缘关系的之间,这就大大地限制了管道的使用。有名管道的出现突破了这种限制,它可以使互不相关的两个实现彼此通信。该管道可以通过路径名来指出,并且在文件系统中是可见的。在建立了管道之后,两个就可以把它当作普通文件一样进行读写操作,使用非常方便。不过值得注意的是,FIFO是严格地遵循先进先出规则的,对管道及FIFO的读总是从开始处返回数据,对它们的写则把数据添加到末尾,它们不支持如lseek()等文件定位操作。

有名管道的创建可以使用函数mkfifo(),该函数类似文件中的open()操作,可以指定管道的路径和打开的模式。

小知识

用户还可以在命令行使用“mknod管道名p”来创建有名管道。

在创建管道成功之后,就可以使用open()、read()和write()这些函数了。与普通文件的开发设置一样,对于为读而打开的管道可在open()中设置O_RDONLY,对于为写而打开的管道可在open()中设置O_WRONLY,在这里与普通文件不同的是阻塞问题。由于普通文件的读写时不会出现阻塞问题,而在管道的读写中却有阻塞的可能,这里的非阻塞标志可以在open()函数中设定为O_NONBLOCK。下面分别对阻塞打开和非阻塞打开的读写进行讨论。

(1)对于读进程。

n 若该管道是阻塞打开,且当前FIFO内没有数据,则对读进程而言将一直阻塞到有数据写入。

n 若该管道是非阻塞打开,则不论FIFO内是否有数据,读进程都会立即执行读操作。即如果FIFO内没有数据,则读函数将立刻返回0。

(2)对于写进程。

n 若该管道是阻塞打开,则写操作将一直阻塞到数据可以被写入。

n 若该管道是非阻塞打开而不能写入全部数据,则读操作进行部分写入或者调用失败。

2.mkfifo()函数格式

表8.4列出了mkfifo()函数的语法要点。

表8.4 mkfifo()函数语法要点

所需头文件

#includesys/types.h>
#includesys/state.h>

函数原型

intmkfifo(constchar*filename,mode_tmode)

函数传入值

filename:要创建的管道

函数传入值

mode:

O_RDONLY:读管道

O_WRONLY:写管道

O_RDWR:读写管道

O_NONBLOCK:非阻塞

函数传入值

mode:

O_CREAT:如果该文件不存在,那么就创建一个新的文件,并用第三个参数为其设置权限

O_EXCL:如果使用O_CREAT时文件存在,那么可返回错误消息。这一参数可测试文件是否存在

函数返回值

成功:0

出错:-1

表8.5再对FIFO相关的出错信息做一归纳,以方便用户查错。

表8.5 FIFO相关的出错信息

EACCESS

参数filename所指定的目录路径无可执行的权限

EEXIST

参数filename所指定的文件已存在

ENAMETOOLONG

参数filename的路径名称太长

ENOENT

参数filename包含的目录不存在

ENOSPC

文件系统的剩余空间不足

ENOTDIR

参数filename路径中的目录存在但却非真正的目录

EROFS

参数filename指定的文件存在于只读文件系统内

linux操作系统文章专题:linux操作系统详解(linux不再难懂)

linux相关文章:linux教程


数字通信相关文章:数字通信原理


通信相关文章:通信原理




评论


相关推荐

技术专区

关闭