pipe()

本文介绍了通信方式中的单工、半双工和全双工,重点讲解了匿名管道和命名管道的概念与区别。匿名管道适用于父子进程间通信,而命名管道则通过FIFO文件实现任意两个进程间的通信,支持跨进程甚至跨计算机通信,遵循先进先出原则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

管道是一种最基本的 一种简单的 进程间通信 (IPC)机制,作用于有血缘关系的进程之间,完成数据传递。调用pipe系统函数即可创建一个管道。有如下特质:
       1. 其本质是一个伪文件(实为内核缓冲区)
       2. 由两个文件描述符引用,一个表示读端,一个表示写端
       3. 规定数据从管道的写端流入管道,从读端流出。
管道的原理: 管道实为内核使用环形队列机制,借助内核缓冲区(4k)实现。
管道的局限性:
      A 数据自己读不能自己写;
      B 数据一旦被读走,便不在管道中存在,不可反复读取;
      C 由于管道采用半双工通信方式。因此,数据只能在一个方向上流动。
      D 只能在有公共祖先的进程间使用管道。

常见的通信方式有,单工通信、半双工通信、全双工通信。

匿名管道:

只能用于具有血缘关系的进程间通信,因此在这里我们可以调用fork函数,创建一个子进程,然后让父子进程通过管道进行通信;

同样可以在multiprocessing的Process中使用匿名管道来做父子进程之间的通信;

命名管道:

命名管道可在同一台计算机的不同进程之间或在跨越一个网络的不同计算机的不同进程之间,支持可靠的、单向或双向的数据通信第二,它只能实现一个进程写另一个进程读,而如果需要两者同时进行时,就得重新打开一个管道。 
为了使任意两个进程之间能够通信,就提出了命名管道(named pipe 或 FIFO)。 
1、与管道的区别:提供了一个路径名与之关联,以FIFO文件的形式存储于文件系统中,能够实现任何两个进程之间通信。而匿名管道对于文件系统是不可见的,它仅限于在父子进程之间的通信。 
2、FIFO是一个设备文件,在文件系统中以文件名的形式存在,因此即使进程与创建FIFO的进程不存在血缘关系也依然可以通信,前提是可以访问该路径。 

3、FIFO(first input first output)总是遵循先进先出的原则,即第一个进来的数据会第一个被读走。

匿名管道

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值