一 无名管道:
特点: 具有亲缘关系的进程间通信,但不仅仅指父子进程之间哦。
(1)无名管道的创建
int pipe(int pipefd
参数:
pipefd 数组的首地址
返回值:
成功返回0,失败返回-1
注意:
无名管道存在内核空间,创建成功会给用户空间两个文件描述符,fd[0]:读管道 fd[1]:写管道
思考:为什么无名管道只能用于亲缘关系间进程通信?
因为只有具有亲缘关系的进程存在数据拷贝 [拷贝文件描述符]
二。有名管道
特点:
(1)任意进程间通信
(2)文件系统中存在文件名
<1>创建有名管道文件
int mkfifo(const char *pathname, mode_t mode);
参数:
@pathname 文件名
@mode 指定的权限
返回值:
成功返回0,失败返回-1
<2>打开有名管道文件
open
注意:
一个进程以只读方式打开管道文件,则阻塞,直到另一个进程以写的方式打开管道文件
一个进程以只写方式打开管道文件,则阻塞,直到另一个进程以读的方式打开管道文件
<3>读写管道
read / write
下面加上一个管道之间通信的例子:
负责从管道中读
<pre name="code" class="cpp"> <pre name="code" class="cpp">#include <head.h> int read_fifo(int fd) { int n; char buf[1024]; while(1) { n = read(fd,buf,sizeof(buf) - 1); buf[n] = '\0'; printf("Read %d bytes : %s\n",n,buf); if(strncmp(buf,"quit",4) == 0) break; } return 0; } //./a.out fifoname int main(int argc, const char *argv[]) { int fd; if(argc < 2) { fprintf(stderr,"Usage : %s argv[1]\n",argv[0]); exit(EXIT_FAILURE); } //创建有名管道 if(mkfifo(argv[1],0666) < 0 && errno != EEXIST) { fprintf(stderr,"Fail to mkfifo %s : %s\n",argv[1],strerror(errno)); exit(EXIT_FAILURE); } fd = open(argv[1],O_RDONLY); if(fd < 0){ fprintf(stderr,"Fail to %s : %s\n",argv[1],strerror(errno)); exit(EXIT_FAILURE); } printf("Open success for read!\n"); read_fifo(fd); return 0; }
#include <head.h> int write_fifo(int fd) { char buf[1024]; while(1) { printf("input >"); fgets(buf,sizeof(buf),stdin); buf[strlen(buf) - 1] = '\0'; write(fd,buf,strlen(buf)); if(strncmp(buf,"quit",4) == 0) break; } return 0; } //./a.out fifoname int main(int argc, const char *argv[]) { int fd; if(argc < 2) { fprintf(stderr,"Usage : %s argv[1]\n",argv[0]); exit(EXIT_FAILURE); } //创建有名管道 if(mkfifo(argv[1],0666) < 0 && errno != EEXIST) { fprintf(stderr,"Fail to mkfifo %s : %s\n",argv[1],strerror(errno)); exit(EXIT_FAILURE); } fd = open(argv[1],O_WRONLY); if(fd < 0){ fprintf(stderr,"Fail to %s : %s\n",argv[1],strerror(errno)); exit(EXIT_FAILURE); } write_fifo(fd); return 0; }
原文地址:http://blog.csdn.net/u011401496/article/details/38564267