Linux入门:命名管道

       匿名管道的一个不足之处是没有名字,因此用于具有亲缘关系的进程间通信。在命名管道提出后,该限制得到了解决。命名管道是一个设备文件,因此,即使进程与创建FIFO的进程不存在亲缘关系,只要可以访问该路径,就能够通过FIFO 相互通信。值得注意的是,FIFO(first input first output)总是按照先进先出的原则工作,第一个被写入的数据将首先从管道中读出。

       Linux下有两种方式创建命名管道。一是在Shell下交互地建立一个命名管道,二是在程序中使用系统函数建立命名管道。Shell方式下创建命名管道的系统函数有两个:mknod和mkfifo。函数原型如下: 

int mknod(const char *path,mode_t mode,dev_t dev);

int mkfifo(const char *path,mode_t mode); 

函数mknod参数中path为创建的命名管道的全路径名;mode为创建的命名管道的模式,指明其存取权限;dev为设备值,该值取决于文件创建的种类,它只在创建设备文件时才会用到。这两个函数调用成功都返回0,失败都返回-1。函数mkfifo与mknod的两个参数含义相同。

下面使用mkfifo创建一个管道:

if (mkfifo("/tmp/fifo",S_IFIFO|0666) == -1)  
 {   
       perror("mkfifo error!");   
       exit(1);   
}
对于mkfifo的第二个参数为存取权限,S_IFIFO|0666表示创建的管道的权限为666, 即创建者、与创建者同组的用户、其他用户对该命名管道的访问权限都是可读可写。

命名管道创建后就可以使用了,命名管道和匿名管道的使用方法基本是相同的。只是使用命名管道时,必须先调用open()将其打开。因为命名管道是一个存在于硬盘上的文件,而匿名管道是存在于内存中的特殊文件。     

需要注意的是,调用open()打开命名管道的进程可能会被阻塞。但如果同时用读写方式 (O_RDWR)打开,则一定不会导致阻塞;如果以只读方式(O_RDONLY)打开,则调用open()函数的进程将会被阻塞直到有写方打开管道;同样以写方式(O_WRONLY)打开 也会阻塞直到有读方式打开管道。


下面就来创建命名管道实现进程间通信:

server端:





client端:




运行结果:




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值