又要考试了

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

复制代码
#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;
}

四、思维导图

相关推荐
奇迹_h2 小时前
打造你的HTML5打地鼠游戏:零基础入门实践
前端
SuperEugene2 小时前
Vue生态精选篇:Element Plus 的“企业后台常用组件”用法扫盲
前端·vue.js·面试
Neptune12 小时前
JavaScript回归基本功之---类型判断--typeof篇
前端·javascript·面试
贾铭2 小时前
如何实现一个网页版的剪映(三)使用fabric.js绘制时间轴
前端·后端
xiaoye20182 小时前
Lettuce连接模型、命令执行、Pipeline 浅析
java
子兮曰3 小时前
后端字段又改了?我撸了一个 BFF 数据适配器,从此再也不怕接口“屎山”!
前端·javascript·架构
万少5 小时前
使用Trae轻松安装openclaw的教程-附带免费token
前端·openai·ai编程
浪浪山_大橙子5 小时前
OpenClaw 十分钟快速,安装与接入完全指南 - 推荐使用trae 官方 skills 安装
前端·人工智能
忆江南5 小时前
iOS 可视化埋点与无痕埋点详解
前端
离开地球表面_995 小时前
金三银四程序员跳槽指南:从简历到面试再到 Offer 的全流程准备
前端·后端·面试