无名管道缺点:不同进程不能通信
解决方法:取名
无名管道:
· 管道是半双工的,数据只能由一个进程流向另一个进程(其中一个读管道,一个写管道);如果要进行双方通信,需要建立两个管道;
**·**管道只能用于父子进程或者兄弟进程间通信。也就是说无名管道只能用于具有亲缘关系的进程间通信。
必须在系统调用fork()前调用pipe(),否则子进程将不会继承文件描述符
(1)如果管道的写端不存在,则认为已经读到数据末尾,该函数返回的读出字节数为0
(2)如管道写端不存在时,如果请求的字节数目大于PIPE_BUF,则返回现有的数据字节数;如果不大于,则返回现有数据字节数,或请求字节数
有名管道
int mkfifo(const char *pathname,mode_t mode)
mode:
O_WRONLY(可读)
O_EDONLY(可写)
有名管道特点:
- 既可用于本地,又可用于网络。
- 可以通过它的名称而被引用。
- 支持多客户机连接。
- 支持双向通信。
- 支持异步重叠I/O操作。
命名管道的用途主要有:(1)shell命名使用FIFO将数据从一条管道传送到另一条时,无须创建中间临时文件;(2)在客户进程和服务器进程间传送数据。