有名管道FIFO,进行两个独立进程的双向通信

这篇博客介绍了如何利用有名管道FIFO实现两个独立进程之间的双向通信。通过在C语言环境中使用fork()函数创建子进程和父进程,然后结合write()和read()函数进行数据的发送和接收。内容详述了进程1中子进程向进程2的子进程发送数据,而进程2的父进程则向进程1的父进程发送数据的过程。

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

        为实现两个独立进程之间的通信,我们需要给两个独立的进程创建子进程和父进程。

        利用fork()函数创建进程的子进程和父进程。

        进程1中子进程用来发送数据给进程2中的子进程,进程2中的父进程发送数据给进程1中的父进程。

        发送和接收过程中运用到文件的读写函数 write()和read()。

        两个进程的创建与通信如图:

 

进程1中的创建父子进程以及接收发送:

#include <stdio.h>
#include <unistd.h>
#include <pthread.h>
#include <sys/types.h>
#include <string.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <errno.h>
#define FIFO1 "myfifo1"
#define FIFO2 "myfifo2"

int main(int argc, const char *argv[])
{
	pid_t pid;
	pid = fork();
	if(pid < 0)
	{
		perror("fork error!");
		return -1;
	}
	//子进程发送
	if(pid == 0)
	{
		if(mkfifo(FIFO
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值