Linux管道通信C语言编程示例 |
本文标签:Linux,管道通信,C语言,编程示例 一、定义 管道是单向的、先进先出的 。它将一个程序的输入和另一个程序的输出连接起来 。数据被一个进程读出后,将被从管道中删除 。分为无名和有名管道两种 。前者用于父进程和子进程间的通信,后者用于同一系统的两个进程间通信 。 复制代码 代码如下: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 , its %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! Its %s\n",num,buff); } 4、管道关闭:用close()关闭相应的文件描述符即可 。 |