Linux--进程间通信--管道

本文详细介绍了Linux系统中的管道通信,包括无名管道的创建、关闭及特点,强调其只能用于具有亲缘关系的进程间半双工通信。同时,解释了命名管道(FIFO)的概念,它是存在于文件系统中的特殊设备文件,允许无关联进程间的通信。通过mkfifo函数创建命名管道,并讨论了读写操作可能导致的阻塞问题。
摘要由CSDN通过智能技术生成

一.管道通信(无名管道)

1.用途:管道主要用于父子进程或者兄弟进程间的数据读写,命名管道则可以在无关联的进程间进行沟通传递数据。

2.在Linux系统中的进程通信中,管道某一时刻只能单一方向传递数据,不能双向传递数据,这种工作模式就叫做半双工模式。半双工工作模式的管道通信是只能从一端写数据,从另一端读数据。

3. 管道创建和管道关闭
管道由Linux系统提供的pipe()函数创建,该函数原型为:

#include <unistd.h>
int pipe(int filedes[2]);

 pipe()函数用于在内核中创建一个管道,该管道一端用于读取管道中的数据,另一端用于将数据写入管道。在创建一个管道后,会获得一对文件描述符,用于读取和写入,然后将参数数组filedes中的两个值传递给获取到的两个文件描述符,filedes[0]指向管道的读端,filedes[1]指向写端。


pipe()函数调用成功,返回值为0;否则返回-1,并且设置了适当的错误返回信息。此函数只是创建了管道,要想从管道中读取数据或者向管道中写入数据,需要使用read()和write()函数来完成。当管道通信结束后,需要使用close()函数关闭管道的读写端。
 

4.管道特点:

      1.只能用于具有共同祖先的进程(具有亲缘关系的进程)之间进行通信;通常,一个管道由一           个进程创建,然后该进程调用fork(),此后父子进程之间就可以应用该管道。
       2.一般而言,进程退出,管道释放,所以管道的生命周期跟随进程。
       3.一般而言,内核会对管道操作进行同步与互斥
       4.管道是半双工的,数据只能向一个方向流动;需要双方通信时,需要建立起两个管道。

5. pipe()函数实现管道通信

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值