23111 IO进程线程 day6
2024-01-08 22:40:19
使用有名管道,完成两个进程的相互通信
create.c
#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
#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
#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;
}
文章来源:https://blog.csdn.net/z2606200330/article/details/135466972
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!