Linux中怎么实现管道通信

发布时间:2021-06-23 16:26:05 作者:Leah
来源:亿速云 阅读:181

Linux中怎么实现管道通信,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

一、定义

管道是单向的、先进先出的。它将一个程序的输入和另一个程序的输出连接起来。数据被一个进程读出后,将被从管道中删除。分为无名和有名管道两种。前者用于父进程和子进程间的通信,后者用于同一系统的两个进程间通信。
 
二、无名管道

代码如下:


    int  pipe(int fd[2]);


   其中,fd[0]用于读管道,fd[1]用于写管道。若成功则返回零,否则返回-1,错误原因存于errno中。

Linux中怎么实现管道通信

三、有名管道: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);
}

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

推荐阅读:
  1. [Linux管道和IPC]命名管道操作--命名管道通信接收服务器端
  2. [Linux管道和IPC]命名管道操作--命名管道通信发送客户端

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

linux

上一篇:Linux中如何使用tee命令

下一篇:Linux中怎么实现共享内存

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》