系统运维

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);
}

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注资讯频道。