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;
}
相关推荐
小安运维日记20 分钟前
Linux云计算 |【第四阶段】NOSQL-DAY1
linux·运维·redis·sql·云计算·nosql
kejijianwen1 小时前
JdbcTemplate常用方法一览AG网页参数绑定与数据寻址实操
服务器·数据库·oracle
编程零零七1 小时前
Python数据分析工具(三):pymssql的用法
开发语言·前端·数据库·python·oracle·数据分析·pymssql
CoolTiger、3 小时前
【Vmware16安装教程】
linux·虚拟机·vmware16
(⊙o⊙)~哦3 小时前
JavaScript substring() 方法
前端
无心使然云中漫步4 小时前
GIS OGC之WMTS地图服务,通过Capabilities XML描述文档,获取matrixIds,origin,计算resolutions
前端·javascript
Bug缔造者4 小时前
Element-ui el-table 全局表格排序
前端·javascript·vue.js
学习3人组4 小时前
CentOS 中配置 OpenJDK以及多版本管理
linux·运维·centos
xnian_4 小时前
解决ruoyi-vue-pro-master框架引入报错,启动报错问题
前端·javascript·vue.js
厨 神5 小时前
vmware中的ubuntu系统扩容分区
linux·运维·ubuntu