系统运维
Linux中怎么实现管道通信,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
一、定义
管道是单向的、先进先出的。它将一个程序的输入和另一个程序的输出连接起来。数据被一个进程读出后,将被从管道中删除。分为无名和有名管道两种。前者用于父进程和子进程间的通信,后者用于同一系统的两个进程间通信。
二、无名管道
代码如下:
int pipe(int fd[2]);
其中,fd[0]用于读管道,fd[1]用于写管道。若成功则返回零,否则返回-1,错误原因存于errno中。
三、有名管道:FIFO
代码如下:
int mkfifo(const char* pathname,mode_t mode)
open时使用O_NONBLOCK,访问要求无法满足则立即出错返回。erron是ENXIO。
例子:
代码如下:
fread.c //读文件</p><p>#include<errno.h>
#include<memory.h>
#define FIFO “myfifo”
main(){
int fd;
char buff[100];
if(access(FIFO,F_OK) == -1){
mkfifo(FIFO,0777);
}
fd=open(FIFO,O_RDONLY|O_NONBLOCK); //设置非阻塞打开,否则当没有输入时,会阻塞在read函数 </p><p> int num;
while(1){
memset(buff,’\\0′,100); //如不清空最后的字符会出现乱码
if((num=read(fd,buff,100))==0){
printf(“waiting…..\\n”);
sleep(1);
continue;
}
printf(“read %d in fifo , it’s %s”,num,buff);
sleep(1);
}
}</p><p>
fwrite.c //写文件</p><p> </p><p>#include<stdio.h>
#include<fcntl.h>
#include<memory.h>
#define FIFO “myfifo”
main(){
int fd;
char buff[100];
memset(buff,’\\0′,100);
scanf(“%s”,buff);
if(access(FIFO,F_OK) == -1){
mkfifo(FIFO,0777);
}
fd=open(FIFO,O_WRONLY);
int num;
num=write(fd,buff,strlen(buff));
printf(“%d char is written! It’s %s\\n”,num,buff);
}
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注资讯频道。