linux 进程间通信——管道

本文深入探讨了无名管道(pipe)和有名管道(fifo)在进程间通信的应用。详细介绍了如何创建和使用这两种管道,以及在双向通信场景下为何通常会选择关闭一端的原因,避免死锁并确保数据正确传输。

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

基本应用

  1. 无名管道(pipe)
//1. 创建一个有两个元素的一维数组 	
int pipe[2];
//2. 使用pipe或pipe2函数将数组变为无名管道 
if(0 == pipe(pipe)) //(pipe[0]--读,pipe[1]--写)
//3. 创建一个子进程 
pid_t pid = fork();
//4. 子进程和父进程按需要关闭其中一端
if(pid == 0) //子进程
{
	if(child write to parent)
		close(pipe[0]);
	else
		close(pipe[1]);
}
else if(pid > 0) //父进程
{
	if(child write to parent)
  		close(pipe[1]);
 	else
  		close(pipe[0]);
}

}
else 
	//fork出错
  1. 有名管道(fifo)
//1. 定义一个有效文件路径
char *path = ".";	//当前目录路径
//2. 创建有名管道fifo
mkfifo(path, 0644);
//3. 打开有名管道
int fd = open(path, flag);

无名管道双向通信的可行性

  1. 上面无名管道的基本应用中会关闭一端,这样是为什么?
    是无名管道不能双向通信吗? 可以!子进程和父进程既可以通过一个无名管道读也可以写。
  2. 那为什么用关闭一端呢?
    a. 因为无名管道的读端和写端用的是一块内存;
    b. 子进程写进去的内容也可能被子进程读出来;
    c. 如果子进程和父进程同时读,这可能会同时阻塞在读上,从而造成死锁。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值