码迷,mamicode.com
首页 > 其他好文 > 详细

IPC——管道(Pipe)

时间:2015-05-20 13:20:23      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:unix   ipc   管道   

用于进程间通信的有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 }
~        



IPC——管道(Pipe)

标签:unix   ipc   管道   

原文地址:http://blog.csdn.net/u010275850/article/details/45867621

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!