进程间通信与同步

进程之间的通信指数据突破进程空间的隔离,完成数据在进程间传递。

管道

进程间的管道通信方式有两种形式,无名管道用于父子进程间,命名管道可以用在任意进程间。

无名管道

管道是单向的信道,进程从管道的写端口写入数据,需要数据从读端口中获取数据,数据在管道中按到达顺序流动。
下面展示一个父子进程用无名管道通信的例子:
pipe()用两个文字描述符来指代管道通信的读端和写端(fsn[]数组)。其中父进程关闭了管道的读端fds【0】并往管道的写端fds【1】写出信息,子进程关闭了管道的写端fds[1]并从管道的读端fds[0]读回信息。
在这里插入图片描述在这里插入图片描述

命名管道:

前面提到的无名管道有一个主要缺点,只能通过父子进程之间(及其后代 )使用文件描述符的继承来访问,无法在任意的进程之间使用。命名管道 (named pipe)或者叫FIFO则突破了这个限制 。可以说FIFO就是无名管道的升级版—— 有可访问的磁盘索引节点,即FIFO文件将出现在目录树中(不像无名管道那样只存在于pipefs特殊文件系统中)。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在Linux中执行ipcs命令可以查看到当前系统中所有的System V IPC对象 ,如图所示。此时系统中还没有创建消息队列和信号量数组(或称信号量集&#x

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值