又要考试了

一、实现无名管道练习:父进程写入管道,子进程读取管道数据。

复制代码
#include<myhead.h>
int main(int argc, const char *argv[])
{
	int fd[2];
	char buff[1024]="王吕阳,崔庆权别卷了";
	char s[1024];
	if(pipe(fd)==-1)
	{
		perror("pipe");
		return -1;
	}
	pid_t pid = fork();
	if(pid==0)
	{
		close(fd[1]);//关闭写端
		while(1)
		{
			sleep(1);
			read(fd[0],s,sizeof(s));
			printf("展旗善意提醒:%s\n",s);
		}
		close(fd[0]);//关闭读端
	}else if(pid>0)
	{
		close(fd[0]);//关闭读端
		while(1)
		{
			sleep(1);
			write(fd[1],buff,sizeof(buff));
		}
		close(fd[1]);
	}else
	{
		perror("fork");
		return -1;
	}
	return 0;
}

二、有名管道练习实现一遍练习:创建2个子父进程,父进程写入管道1,子进程读取管道2,父进程写入管道2,子进程读取管道1,实现全双工通信。

复制代码
#include<myhead.h>
int main(int argc, const char *argv[])
{
	int fd1 = open("./a",O_WRONLY);
	int fd2 = open("./b",O_RDONLY);
	char arr[1024];
	char brr[1024];
	if(fd1==-1||fd2==-1)
	{
		perror("open");
		return -1;
	}
	pid_t pid = fork();
	if(pid>0)
	{
		while(1)
		{
			printf("请输入内容:");
			int res = read(0,arr,sizeof(arr));
			write(fd1,arr,res);
		}
		close(fd1);

	}else if(pid==0)
	{
		while(1)
		{
			int ress = read(fd2,brr,sizeof(brr));
			if(ress==0)
			{
				printf("退出\n");
				break;
			}
			write(1,brr,ress);
		}
		close(fd2);
	}else
	{
		perror("fork");
		return -1;
	}
	return 0;
}

#include<myhead.h>
int main(int argc, const char *argv[])
{
	int fd1 = open("./a",O_RDONLY);
	int fd2 = open("./b",O_WRONLY);
	char arr[1024];
	char brr[1024];
	if(fd1==-1||fd2==-1)
	{
		perror("open");
		return -1;
	}
	pid_t pid = fork();
	if(pid>0)
	{
		while(1)
		{
			printf("请输入内容:");
			int ress = read(0,brr,sizeof(brr));
			write(fd2,brr,ress);
		}
		close(fd2);

	}else if(pid==0)
	{
		while(1)
		{
			int res = read(fd1,arr,sizeof(arr));
			if(res==0)
			{
				printf("退出\n");
				break;
			}
			write(1,arr,res);
		}
		close(fd1);
	}else
	{
		perror("fork");
		return -1;
	}
	return 0;
}

三、进程间通信信号的默认,忽略,捕获实现一遍。

复制代码
#include<myhead.h>
void a(int b)
{
	if(b==SIGTSTP)
	{
		printf("A\n");
	}
}
int main(int argc, const char *argv[])
{
/*	if(signal(SIGINT,SIG_IGN)==SIG_ERR)
	{
		perror("signal");
		return -1;
	}

	if(signal(SIGINT,SIG_DFL)==SIG_ERR)
	{
		perror("signal");
		return -1;
	}
	*/
	if(signal(SIGTSTP,a)==SIG_ERR)
	{
		perror("signal");
		return -1;
	}
	int k=0;
	while(1)
	{
		sleep(1);
		printf("按k=%d\n",k);
		k++;
	}
	return 0;
}

四、思维导图

相关推荐
serene942 分钟前
IntelliJ IDEA 2025.2 和 JetBrains Rider 2025.1 恢复git commit为模态窗口
java·git·intellij-idea
南客先生5 分钟前
5G融合消息PaaS项目深度解析 - Java架构师面试实战
java·微服务·高并发·paas·分布式系统·缓存策略·5g融合消息
幽络源小助理8 分钟前
SpringBoot物资管理系统 | JavaWeb项目设计与实现
java·springboot·javaweb
掘金詹姆斯15 分钟前
LangChain4j—人工智能服务 AIService(三)
java·人工智能
掘金詹姆斯16 分钟前
LangChain4j—聊天记忆 Chat memory(四)
java·人工智能
Chase_______16 分钟前
Java后端开发——分层解耦详解
java·开发语言·spring·web
喝可乐的布偶猫18 分钟前
Java----super 关键字
java·开发语言
一天睡25小时18 分钟前
前端性能优化面试回答技巧(一)
前端·面试
樊小肆18 分钟前
Vue3 在线 PDF 编辑 2.0 缩放拖拽、渲染优化功能解析
前端·vue.js·开源
程序员韩立19 分钟前
精通 React Hooks:从核心技巧到自定义实践
前端