管道

本文深入探讨了mkfifo与pipe两种创建管道的方法,解释了它们之间的区别,包括占用资源、性能差异以及使用场景。重点强调了在本地通信时,管道的效率通常更高。

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

mkfifo 得到的是有名管道。它占用磁盘上的一个 I-节点。这个 I-节点比较特殊,是一个 “管道” 节点。这样的管道,在外界看起来像是一个文件。


pipe() 得到的是匿名管道,不占用磁盘上的 I-节点。外界一般看不到它,故称 “匿名” 管道。

管道、UNIX 域 sockets 都只能提供本机通信,如果两台计算机的进程之间要通信的话可能需要用 Internet 域 sockets

如果都在本地用,我相信管道的效率更高一些。如果用 sockets,数据会在协议之间层层转发,合并、分解、校验,并且需要经过设备驱动程序,显然就要慢了。


fifo 双向的,但是pipe是单向的,这就意味着如果你的程序需要利用pipe去
做一个duplex的读写传输的话,你需要 int fd[2] 哦!
但是fifo就没有这么复杂了啊!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值