Linux C命名管道实现进程间通信
来源:互联网 发布:mac剪切文件夹 编辑:程序博客网 时间:2024/06/10 09:52
命名管道实现进程间通信
命名管道
命名管道也被称为FIFO文件,它是一种特殊类型的文件,它在文件系统中以文件名的形式存在,但是它的行为却和之前所讲的没有名字的管道(匿名管道)类似。
命名管道也被称为FIFO文件,它是一种特殊类型的文件,它在文件系统中以文件名的形式存在,但是它的行为却和之前所讲的没有名字的管道(匿名管道)类似。
创建命名管道
以下两个函数都可以用来创建命名管道(任选一个),函数原型如下:
以下两个函数都可以用来创建命名管道(任选一个),函数原型如下:
#include <sys/types.h> #include <sys/stat.h> int mkfifo(const char *filename, mode_t mode); int mknod(const char *filename, mode_t mode | S_IFIFO, (dev_t)0);
mkfifo函数,filename表示文件名,mode则表示文件的读写权限。
mknod函数,参数中path为创建的命名管道的全路径名:mod为创建的命名管道的模式,指明其存取权限;dev为设备值,该值取决于⽂件创建的种类,它只在创建设备⽂件时才会⽤到。这两个函数调⽤成功都返回0,失败都返回-1。
另外,mknod属于较老的函数,而mkfifo函数使用起来更见简单规范,建议使用mkfifo函数。
这两个函数都能创建一个FIFO文件,但其实是创建了一个确实存在与文件系统中的文件,命名管道在创建后就可以使用了,命名管道和管道的使用方法基本相同,但是使用命名管道是,必须调用open函数将其打开。
open阻塞
调用open()打开命名管道的进程是可能会被阻塞,如果以只读(O_RDONLY)打开,调用open()函数的进程将会被阻塞直到有写方式打开管道;同样的以写的方式(O_WRONLY)打开也会阻塞直到有读方式打开管道;另外如果不希望在进行命名管道操作时发生阻塞,可以在oprn()调用中使用O_NONBLOCK标志,以关闭默认的阻塞动作。
下面来看一个简单的例子:
write端
write端
#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 200int main(){ int a=mkfifo(PATH,0666|S_IFIFO); if(a==-1) { perror("mkfifo error!"); exit(0); } int fd=open(PATH,O_WRONLY); if(fd < 0) { printf("open file error!\n"); return 0; } char buffer[SIZE]; memset(buffer,'\0',sizeof(buffer)); while(1) { read(0,buffer,sizeof(buffer)); int b=write(fd,buffer,strlen(buffer)-1); buf[b]='\0'; if(b < 0) { printf("wirte error!\n"); break; } if(strncmp(buffer,"end",3)==0) { break; } } close(fd); return 0;}
read端
#include<stdio.h>#include<sys/types.h>#include<sys/stat.h>#include<fcntl.h>#include<string.h>#include<unistd.h>#define PATH "./myfifo"#define SIZE 200int main(){ int fd =open(PATH,O_RDONLY); if(fd<0) { printf("open file error!\n"); return 0; } char buffer[SIZE]; memset(buffer,'\0',sizeof(buffer)); while(1) { int a=read(fd,buffer,sizeof(buffer)); if(a<=0) { printf("read end or error!\n"); break; } printf("%s\n",buffer); if(strncmp(buffer,"end",3)==0) { break; } } close(fd); return 0;}
先运行write端,再运行read端,在write端输入数据,就可以在read端读出数据,直到输入end结束通信。
阅读全文
0 0
- Linux C命名管道实现进程间通信
- linux进程间的通信(C): 命名管道
- Linux--进程间通信之命名管道(代码实现)
- 使用命名管道实现进程间通信
- 使用命名管道实现进程间通信
- 使用命名管道实现进程间通信
- 进程间通信 - 命名管道实现
- 进程间通信详解 - 命名管道实现
- 命名管道实现进程间通信
- 进程间通信 - 命名管道实现
- 进程间通信详解 - 命名管道实现
- 进程间通信 - 命名管道实现
- 进程间通信 - 命名管道实现
- 使用命名管道实现进程间通信
- 进程间通信 - 命名管道实现
- 进程间通信 - 命名管道实现
- 进程间通信 - 命名管道实现
- 进程间通信 - 命名管道实现
- 输入比赛成绩
- 纷享销客 java开发实习生面经
- Dapper-一个简单的.Net对象映射器
- DFS子集
- 使用git来连接mysql
- Linux C命名管道实现进程间通信
- xshell连接ubuntu虚拟机(NAT模式)
- 循环双链表的删除
- 动态规划之矩阵连乘
- crontab定时任务
- C++中 引用符&,以int&举例说明
- SQL的函数---3th
- STM32 里 FWLib解释
- 机器学习入门(一)