23111 IO进程线程 day6

使用有名管道,完成两个进程的相互通信

create.c

cs 复制代码
#include<myhead.h>


int main(int argc, const char *argv[])
{
	//创建两个管道文件
	if(mkfifo("./myfifo1",0664)==-1)
	{
		perror("myfifo1 create error");
		return -1;
	}

	if(mkfifo("./myfifo2",0664)==-1)
	{
		perror("myfifo2 create error");
		return -1;
	}
	
	printf("两个管道文件创建成功\n");

	//阻塞进程结束
	getchar();

	system("rm myfifo1 myfifo2");


	return 0;
}

use1.c

cs 复制代码
#include<myhead.h>


int main(int argc, const char *argv[])
{
	pid_t pid;

	pid=fork();

	//父进程从管道1中写数据
	//子进程从管道2中读数据
	if(pid>0)
	{
		//父进程从管道1写数据
		int wfd=-1;
		if((wfd=open("./myfifo1",O_WRONLY))==-1)
		{
			perror("open myfifo1 error");
			return -1;
		}

		char buf[128]="";
		while(1)
		{
			//清空数据
			bzero(buf,sizeof(buf));

			//从终端输入数据
			printf("请输入>>>");

			fgets(buf,sizeof(buf),stdin);
			buf[strlen(buf)-1]='\0';

			//将数据写入管道1
			write(wfd,buf,strlen(buf));
			if(strcmp(buf,"quit")==0)
			{
				break;
			}
		}

		//关闭文件
		close(wfd);

		//回收子进程资源
		wait(NULL);
	}
	else if(pid==0)
	{
		//子进程
		int rfd=-1;
		if((rfd=open("./myfifo2",O_RDONLY))==-1)
		{
			perror("open myfifo2 error");
			return -1;
		}

		char buf[128]="";
		while(1)
		{
			//清空数据
			bzero(buf,sizeof(buf));

			//读取管道2的内容
			read(rfd,buf,sizeof(buf));

			printf("读取的内容为:%s\n",buf);
			if(strcmp(buf,"quit")==0)
			{
				break;
			}
		}

		//关闭文件
		close(rfd);

		//退出进程
		exit(EXIT_SUCCESS);

	}
	else
	{
		perror("fork create error");
		return -1;
	}

	return 0;
}

use2.c

cs 复制代码
#include<myhead.h>


int main(int argc, const char *argv[])
{
	pid_t pid;

	pid=fork();

	//父进程从管道1中读数据
	//子进程从管道2中写数据
	if(pid==0)
	{
		//子进程
		int wfd=-1;
		if((wfd=open("./myfifo2",O_WRONLY))==-1)
		{
			perror("open myfifo2 error");
			return -1;
		}

		char buf[128]="";
		while(1)
		{
			//清空数据
			bzero(buf,sizeof(buf));
			//从终端输入数据
			printf("请输入>>>");

			fgets(buf,sizeof(buf),stdin);
			buf[strlen(buf)-1]='\0';

			//将数据写入管道1
			write(wfd,buf,strlen(buf));
			if(strcmp(buf,"quit")==0)
			{
				break;
			}
		}

		//关闭文件
		close(wfd);

		//退出进程
		exit(EXIT_SUCCESS);
	}
	else if(pid>0)
	{
		//父进程
		int rfd=-1;
		if((rfd=open("./myfifo1",O_RDONLY))==-1)
		{
			perror("open myfifo1 error");
			return -1;
		}

		char buf[128]="";
		while(1)
		{
			//清空数据
			bzero(buf,sizeof(buf));

			//读取管道2的内容
			read(rfd,buf,sizeof(buf));

			printf("读取的内容为:%s\n",buf);
			if(strcmp(buf,"quit")==0)
			{
				break;
			}
		}

		//关闭文件
		close(rfd);

		//回收子进程资源
		wait(NULL);

	}
	else
	{
		perror("fork create error");
		return -1;
	}

	return 0;
}
相关推荐
lolo大魔王33 分钟前
Gin 框架响应格式与 HTML 模板渲染完整实战教程
前端·html·gin
hexu_blog33 分钟前
Linux centos 安装向量数据库milvus
linux·centos·milvus
code monkey.2 小时前
【Linux之旅】Linux 应用层自定义协议与序列化:从粘包问题到网络计算器
linux·网络·c++
wgc2k2 小时前
Node.js游戏服务器项目移植-2: 用TypeScript还是Javascript
服务器·游戏·node.js
草莓熊Lotso2 小时前
【Linux网络】深入理解 HTTP 协议(二):从协议格式到手写工业级 HTTP 服务器
linux·运维·服务器·网络·c++·http
llz_1123 小时前
web-第二次课后作业
前端·后端·web
上海云盾第一敬业销售3 小时前
服务器遭受攻击的应对策略及快速防护实践
运维·服务器·web安全·ddos
vipbic8 小时前
别再把“做个H5”挂嘴边了:这个词,官方压根就没有定义过
前端
剑神一笑8 小时前
Linux pgrep 命令详解:按名称查找进程 PID 的高效方法
linux·运维·chrome
yyuuuzz8 小时前
独立站的技术基础与常见运维问题
大数据·运维·服务器·网络·数据库·aws