Linux--进程间通信之命名管道(代码实现)
来源:互联网 发布:win域名是哪个国家的 编辑:程序博客网 时间:2024/06/10 11:34
一、概念
Linux中的管道,可以分为匿名管道(同常就称为管道),命名管道。
上一篇博客讲的就是匿名管道:Linux进程通信之管道,读者有兴趣可以看一下,本篇博客讲的是命名管道。
管道的不足之处,只能用于有血缘关系的进程。命名管道(FIFO)的提出就突破了管道的限制,管道提供了路径名与之关联,以FIFO的文件形式存储于文件系统中。命名管道可以被不同进程以不同的方式方法调用(可以跨权限、跨语言、跨平台)。只要程序知道命名管道的名字,发送到命名管道里的信息可以被一切拥有指定授权的程序读取,但对不具有制定授权的。命名管道是一种FIFO(先进先出,First-In First-Out)对象。
特点:
1.FIFO是作为一个特殊的设备文件存在;
2.不同祖先进程的进程之间可以共享数据;
3.使用完后FIFO将继续保存。
二、命名管道的创建于读写
我们有调用下面两个函数之一创建命名管道,函数原型如下:
#include <sys/types.h> #include <sys/stat.h> int mkfifo(const char *path, mode_t mode); int mknod(const char *path, mode_t mode | S_IFIFO, (dev_t)0);函数mknod参数中path为创建的命名管道的全路径名;mod为创建的命名管道的模式,指明其存取权限;dev为设备值,该值取决于文件的创建种类,它只在创建设备文件是才会用到。
mkfifo函数前两个参数的意义和mknod函数的参数意义一样。这两个函数调用成功都返回0,失败返回-1.
这两个函数都是创建一个真实存在于系统中的文件,其中mknod是比较老的函数吗,使用mkfifo函数更加规范,所以在可能的情况下,尽可能使用mkfifo函数。
注意:
命名管道创建后就可以使用了,命名管道和管道的使用方法基本相同,只是使用命名管道时,必须先调用open()函数将其打开,因为命名管道存在于硬盘上的文件,管道时存在于内存中的特殊文件。
调用open()函数打开命名管道的进程可能会被阻塞,但如果同时用读写方式打开(O_RDWR)打开,则一定 不会阻塞;如果以只读方式(O_RDONLY)打开,则调用open()函数的进程将会被阻塞直到有些的方式打开管道;同样以写方式(O_WRONLY)打开也会阻塞直到有读方式打开管道。
三、代码实现fifo
#include<stdio.h>#include<sys/types.h>#include<sys/stat.h>#include<unistd.h>#include<fcntl.h>#include<string.h>#define _PATH_ "./myfifo"#define _SIZE_ 100int main(){int ret=mkfifo(_PATH_,0666|S_IFIFO);if (ret == -1){perror("mkfifo error!");return 1;}int fd=open(_PATH_,O_WRONLY);if(fd<0){printf("open file error!\n");return 2;}char buf[_SIZE_];memset(buf,'\0',sizeof(buf));while(1){read(0,buf,sizeof(buf));int ret=write(fd,buf,strlen(buf)-1);buf[ret]='\0';if(ret<0){printf("wirte error!\n");break;}if(strncmp(buf,"quit",4)==0){break;}}close(fd);return 0;}fifo read 端:
#include<stdio.h>#include<sys/types.h>#include<sys/stat.h>#include<unistd.h>#include<fcntl.h>#include<string.h>#define _PATH_ "./myfifo"#define _SIZE_ 100int main(){int fd=open(_PATH_,O_RDONLY);if(fd<0){printf("open file error!\n");return 1;}char buf[_SIZE_];memset(buf,'\0',sizeof(buf));while(1){int ret=read(fd,buf,sizeof(buf));if(ret<=0){printf("read end or error!\n");break;}printf("%s\n",buf);if(strncmp(buf,"quit",4)==0){break;}}close(fd);return 0;}
上面代码实现了命名管的创建,以及两个管道的通信。
- Linux--进程间通信之命名管道(代码实现)
- 进程间通信:管道及命名管道(代码实现)
- Linux进程间通信之命名管道
- 命名管道(FIFO) Linux进程进程间的通信之命名管道(FIFO)
- linux进程间通信(命名管道)
- Linux--进程间通信之匿名管道及命名管道
- linux进程间通信(一)管道和命名管道
- linux进程通信之命名管道
- Linux 进程通信之 命名管道
- 【Linux】进程间通信(IPC)之匿名管道和命名管道以及测试用例
- Linux C命名管道实现进程间通信
- Linux进程间通信之命名管道(FIFO)
- Linux下进程间通信之命名管道
- Linux进程通信之管道(匿名,命名)
- 使用命名管道实现进程间通信
- 使用命名管道实现进程间通信
- 使用命名管道实现进程间通信
- 进程间通信 - 命名管道实现
- ListView小结
- 二九、webpack基本使用流程
- 聚类
- Effective C++ 第三条,尽可能使用const
- MongoDB权威指南第二版--第一天
- Linux--进程间通信之命名管道(代码实现)
- JAVA8 十大新特性详解
- PHP-fastCGI------PHP-fmp
- 树莓派安装rtl8192eu无线网卡驱动
- ORACLE 常用函数
- 利用C#实现图片的垂直镜像
- JSF后台取不到值
- 对OJ题目一个总结(一)
- Mybatis环境配置