一是在 shell 下交互地建立一个有名管道,二是在程序中使用系统函数建立有名管道。shell 方式下可使用 mknod 或 mkfifo 命令,下面命令使用 mknod 创建了一个有名管道:
mknod namepipe |
引用#include
#include
int mknod( const char * pathname , mode_t mode , dev_t dev);
int mkfifo( const char * pathname , mode_t mode);
函数 mknod() 参数中path 为创建的有名管道的全路径名;mod 为创建的有名管道的模式,指明其存取权限;dev 为设备值,该值取决于文件创建的种类,它只在创建设备文件时才会用到。这两个函数成功返回 0,失败则返回 -1。
通过查看相关头文件,可以看到 mode_t 是 unsigned int 类型
使用 mknod() 创建一个有名管道:
引用umask( 0);
if ( mknod ( "/tmp/fifo" , S_IFIFO | 0666 , 0) == - 1) {
perror( "mknod error!");
exit( 1);
}
使用 mkfifo() 创建有名管道,mkfifo() 前两个参数的含义和 mknod() 相同:
引用umask( 0);
if ( mkfifo ( "/tmp/fifo" , S_IFIFO | 0666 , 0) == - 1) {
perror( "mkfifo error!");
exit( 1);
}
“S_IFIFO | 0666" 指明创建一个有名管道且存取权限为 0666 ,即创建者、与创建者同组的用户、其他用户对该有名管道的访问权限都是可读可写。
有名管道创建后就可以使用了,有名管道的和管道的使用方法基本相同。只是使用有名管道时,必须先调用 open() 将其打开,因为有名管道是一个存在硬盘上的文件,而管道是存在内存中的特殊文件。
需要注意的是,调用 open() 打开有名管道的进程可能会被阻塞。但如果同时以读写方式 ( O_RDWR ) 打开,则一定不会导致阻塞;如果以只读方式 ( O_RDONLY ) 打开,则调用 open() 函数的进程将会被阻塞直到有写方打开管道;同样以写方式 ( O_WRONLY ) 打开也会阻塞直到有读方打开管道。