进程间通信之pipe

本文介绍了进程间通信的基本概念,重点讨论了管道(pipe)的实现方式。管道是一种单向通信机制,通过内核中的缓冲区进行数据交换。在创建管道后,父进程和子进程分别关闭不必要的文件描述符以实现通信。当读写操作达到特定条件时,如管道满或空,后续的写入和读取操作会被阻塞。此外,还提到了读写端关闭后对管道通信的影响,包括读到文件末尾、收到SIGPIPE信号等特殊情况。
摘要由CSDN通过智能技术生成

1、定义

每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进程之间要交换数据必须通过内核,在内核中开辟一块缓冲区,进程A把数据从用户空间拷到内核缓冲区,进程B再从内核缓冲区把数据读走,内核提供的这种机制称为进程间通信。


2、管道实现进程通信

(1)父进程创建管道,得到两个文件描述符指向管道的两端

(2)父进程fork出子进程,子进程也有两个文件描述符指向同一管道。

(3)父进程关闭fd[0],子进程关闭fd[1],即父进程关闭管道读端,子进程关闭管道写端(因为管道只支持单向通信)。父进程可以往管道里写,子进程可以从管道里读,管道是环形队列实现的,数据从写端流入从读端流出,这样就实现了进程间通信。 

                                                  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值