首页 存档 技术 查看内容

linux管道的那点事

2018-3-30 13:00 |来自: 互联网 234 0

摘要: 点击上方“蓝字”可以关注我们哦 |本文来自:ChinaUnix博客 |作者:yjchen218 |原文链接:http://blog.chinaunix.net/uid-29259073-id-5760663.html 管道是一种两个进程间进行单向通信的机制。因为管道传递数据的单 ...

点击上方“蓝字”可以关注我们哦



|本文来自:ChinaUnix博客

|作者:yjchen218

|原文链接:http://blog.chinaunix.net/uid-29259073-id-5760663.html



管道是一种两个进程间进行单向通信的机制。因为管道传递数据的单向性,管道又称为半双工管道。管道的这一特点决定了器使用的局限性。管道是Linux支持的最初Unix IPC形式之一,具有以下特点:


  1. 数据只能由一个进程流向另一个进程(其中一个读管道,一个写管道);如果要进行双工通信,需要建 立两个管道。

  2. 管道只能用于父子进程或者兄弟进程间通信。,也就是说管道只能用于具有亲缘关系的进程间通信。


使用管道进行通信时,两端的进程向管道读写数据是通过创建管道时,系统设置的文件描述符进行的。从本质上说,管道也是一种文件,但它又和一般的文件有所不同,可以克服使用文件进行通信的两个问题,这个文件只存在内存中。


通过管道通信的两个进程,一个进程向管道写数据,另外一个从中读数据。写入的数据每次都添加到管道缓冲区的末尾,读数据的时候都是从缓冲区的头部读出数据的。

#include
int pipe(int pipefd[2]);


(匿名)管道两端分别用描述符pipefd[0]及pipefd[1]来描述。需要注意的是,管道两端的任务是固定的,一端只能用于读,有描述符pipefd[0]表示,称其为管道读端;另一端只能用于写,由描述符pipe[1]来表示,称其为管道写端。


该函数创建的管道的两端处于一个进程中间,在实际应用中没有太大意义,因此,一个进程在由pipe()创建管道后,一般再fork一个子进程,然后通过管道实现父子进程间的通信。在此不再作多介绍,下面看看有名管道吧。


管道的一个不足之处就是没有名字,因此,只能用于具有亲缘关系的进程间通信,在有名管道(name pipe或FIFO)提出后,该**得到了解决。FIFO不同与管道之处在与她提供一个路径名与之关联,以FIFO的文件形式存储在文件系统中。有名管道是一个设备文件,因此,即使进程与创建FIFO的进程不存在亲缘关系,只要可以访问该路径,就能够通过FIFO相互通信了。值得注意的是FIFO(First In First Out)总是按照先进先出的原则工作,第一个被写入的数据首先从管道中读出。


在Linux中我们经常使用管道重定向数据。比如:


下面介绍一下创建有名管道的系统调用,有两个,mknod和mkfifo



#include

#include

int mknod(const char *pathname, mode_t mode, dev_t dev);

intmkfifo(constchar*pathname,mode_tmode);


函数mknod参数中pathname为创建有名管道的全路径名,mode为创建有名管道的模式,指明其存取权限;dev为设备值,该值取决于文件创建的种类,它只在创建设备文件是才会用到。这两个函数调用成功都返回0,否则返回-1.


读写有名管道:


#include

ssize_tread(intfd,void*buf,size_tnbytes)

ssize_twrite(intfd,void*buf,size_tnbytes)


接下来给大家演示一下通过有名管道通信的聊天程序。。。


  1. // 李四.c

  2. #include

声明:文章版权归原作者所有 部分文章转自互联网 如有侵权请联系 [邮箱地址] 删除

路过

雷人

握手

鲜花

鸡蛋

相关分类

返回顶部