用于进程间通信的有5种常用方式:管道、FIFO、消息队列、信号量、共享存储等。
管道 (亦被称为无名管道,以区分FIFO:有名管道)顾名思义具有两个对外端口,一个称为读端,一个称为写端。一个进程在管道的写端写数据,另一个进程从管道的读端
读出数据。如下图所示:
管道仅局限于父进程与子进程之间的通信。
管道通信的特点:
1.管道通讯是单向的,有固定的读端和写端。
2. 数据被进程从管道读出后,在管道中该数据就不存在了。
3. 当进程去读取空管道的时候,进程阻塞。
4. 当进程往满管道写数据时,进程阻塞。
5. 系统常量PIPE_BUF规定了内核的管道缓冲区大小。
其中fd[0]表示管道读端,fd[1]表示管道写端
参考书籍《Unix环境高级编程(第三版)》
1 #include "apue.h" 2 3 int main(void) 4 { 5 int n; 6 int fd[2]; 7 pid_t pid; 8 char line[MAXLINE]; 9 10 if(pipe(fd)<0)//创建一个pipe 11 err_sys("pipe error"); 12 13 if((pid=fork())<0) 14 err_sys("fork error"); 15 16 else if (pid>0)//parent process 17 { 18 close(fd[0]); 19 write(fd[1],"enjoy Linux!\n",13); 20 } 21 else//child 22 { 23 close(fd[1]); 24 n=read(fd[0],line,MAXLINE); 25 write(STDOUT_FILENO,line,n); 26 } 27 exit(0); 28 } ~
原文地址:http://blog.csdn.net/u010275850/article/details/45867621