进程间通讯--管道

管道:把一个进程连接到另一个进程的一个数据流称为一个“管道”,通常是用作把一个进程的输出通过管道连接到另一个进程的输入。管道本质上是内核的一块缓存

 

匿名管道是基于文件描述符的通信方式。实现两个进程间的通信时必须通过fork创建子进程,实现父子进程之间的通信

 

读写规则

管道内没有数据时,读端(read)发生阻塞,等待有效数据进行读取

管道容量被数据填满时,写端(write)发生阻塞,等待进程将数据读走再进行写入

如果所有管道写端对应的文件描述符被关闭,read返回0,但会将之前管道里的数据读完

如果所有管道的读端对应的文件描述符被关闭,write操作会产生信号,SIGPIPE,进而导致write进程退出

当要写入的数据量不大于管道的容量(PIPE_BUF)时,linux将保证写入的原子性

当要写入的数据量大于管道容量(PIPE_BUF)时,linux将不再保证写入的原子性

 

特点

只能够进行单向通信

只能够用于有血缘关系(父子,兄弟,爷孙)的进程之间,多常用于父子之间

管道内部自带同步机制:子进程写一条,父进程读一条

管道在进行通信的时候,对外层提供的服务叫做面向字节流的服务

当进程退出之时,管道也随之释放,与文件保持一致

管道的生命周期为随进程,进程结束管道就没了

字节流:以字节来读取和写入,字节数的大小完全取决于自己

 

命名管道本质上是一个管道文件,可以通过命令创建也可以通过函数创建,用户可以看到

特点

  1. 可以进行不相干进程间的通信

  2. 命名管道是一个文件,对于文件的相关操作对其同样适用读写规则

  1. 对于管道文件,当前进程操作为只读时,则进行阻塞,直至有进程对其写入数据

  2. 对于管道文件,当前进程操作为只写时,则进行阻塞,直至有进程从管道中读取数据

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

盼盼编程

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

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

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

打赏作者

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

抵扣说明:

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

余额充值