进程间通信系列(7)匿名管道和命名管道异同

一、匿名管道
1) 由pipe系统调用,管道由父进程建立
2) 单工通信的
3) 在关系进程中进行(父进程和子进程、同一个父进程的两个子进程之间)
4) 管道位于内核空间,其实是一块缓存

二、命名管道(FIFO)
1) 两个没有任何关系的进程之间通信可通过命名管道进行数据传输,
2) 本质是内核中的一块缓存,另在文件系统中以一个特殊的设备文件(管道文件)存在。
3) 两种方式建立FIFO:
* 命令: mkfifo demo.pipe ==> 创建命名管道(命令内部调用mkfifo函数)
* 系统调用mkfifo(pathname, mode);
注: 命名管道必须读和写同时打开,否则单独读或者单独写会引发阻塞。

关于读写特性的相同点:
1.默认都是阻塞性读写;
2.都适用于socket网络通信;
3.阻塞不完整管道(有一端关闭):
  >单纯读时,在所有数据被读取后,read返回0,以表示达到文件尾部;
  >单纯写时,则产生SIGPIPE,如果忽略该信号或捕获该信号并从处理程序返回,则write
   返回-1,同时设errno设置为EPIPE。
4.阻塞完整管道(两端都开启):
  >单纯读时,要么阻塞,要么读到数据;
  >单纯写时,写到管道满时会出错。
5.非阻塞不完整管道(有一端关闭):
  >单纯读时直接报错;
  >单纯写时,则产生SIGPIPE,如果忽略该信号或捕获该信号并从处理程序返回,则write
   返回-1,同时设errno设置为EPIPE。
6.非阻塞完整管道(两端都开启):
  >单纯读时直接报错;
  >单纯写时,写到管道满时会出错。

关于读写特性不同点:
1.打开方式不一致;
  >pipe通过fcntl系统调用来设置O_NOBLOCK来设置非阻塞性读写;

  >FIFO通过fcntl系统调用或open系统调用来设置非阻塞性读写。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

洪流之源

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值