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;
}
相关推荐
兆子龙26 分钟前
用 Auto.js 实现挂机脚本:从找图点击到循环自动化
前端·架构
SuperEugene32 分钟前
表单最佳实践:从 v-model 到自定义表单组件(含校验)
前端·javascript·vue.js
昨晚我输给了一辆AE8633 分钟前
为什么现在不推荐使用 React.FC 了?
前端·react.js·typescript
不会敲代码133 分钟前
深入浅出 React 闭包陷阱:从现象到原理
前端·react.js
不会敲代码136 分钟前
React性能优化:深入理解useMemo和useCallback
前端·javascript·react.js
Dilettante25837 分钟前
我的 Monorepo 实践经验:从基础概念到最佳实践
前端·前端工程化
只会cv的前端攻城狮1 小时前
Elpis-Core — 融合 Koa 洋葱圈模型实现服务端引擎
前端·后端
Java小卷2 小时前
流程设计器为啥选择diagram-js
前端·低代码·工作流引擎
HelloReader2 小时前
Isolation Pattern(隔离模式)在前端与 Core 之间加一道“加密网关”,拦截与校验所有 IPC
前端
兆子龙3 小时前
从 float 到 Flex/Grid:CSS 左右布局简史与「刁钻」布局怎么搞
前端·架构