IOday9作业

该代码示例展示了两个进程如何通过消息队列进行对话,直到接收到quit为止。每个进程分别发送和接收消息,使用msgget,msgrcv,msgsnd函数。另外,还包含了一个使用共享内存的例子,用于字符串的异步变换和显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.要求实现AB进程对话

A进程先发送一句话给B进程,B进程接收后打印

B进程再回复一句话给A进程,A进程接收后打印

重复1.2步骤,当收到quit后,要结束AB进程

提示:两根管道

提示:用一个消息队列,两种类型即可

当对方输入quit后,退出AB进程删除消息队列;

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include<sys/ipc.h>
#include<sys/msg.h>
struct msgp
{
	long mytype;
	char mtext[128];
};
int main(int argc, const char *argv[])
{
	key_t key=ftok("./02.c",1);
	if(key<0)
	{
		perror("ftok");
		return -1;
	}
	int msqid=msgget(key,IPC_CREAT|0664);
	if(msqid<0)
	{
		perror("msgget");
		return -1;
	}
	struct msgp buf;
	
	while(1)
	{
		
		
		if(0==buf.mytype)
			break;
		printf("please puts mtext:");
		scanf("%s",buf.mtext);
		buf.mytype=1;
		
		if(msgsnd(msqid,&buf,sizeof(buf.mtext),0)<0)
		{
			perror("msgsnd");
			return -1;
		}
		if(0==strcmp(buf.mtext,"quit"))
			break;
		msgrcv(msqid,&buf,sizeof(buf.mtext),2,0);
		printf("%ld: %s\n",buf.mytype,buf.mtext);
		if(0==strcmp(buf.mtext,"quit"))
			break;
	}

	return 0;
}

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include<sys/ipc.h>
#include<sys/msg.h>
#include<sys/types.h>
struct msgp
{
	long mytype;
	char mtext[128];
};
int main(int argc, const char *argv[])
{
	key_t key=ftok("./02.c",1);
	if(key<0)
	{
		perror("ftok");
		return -1;
	}
	int msqid=msgget(key,IPC_CREAT|0664);
	if(msqid<0)
	{
		perror("msgget");
		return -1;
	}
	struct msgp rec;
	
	while(1)
	{
		if(msgrcv(msqid,&rec,sizeof(rec.mtext),1,0)<0)
		{
			perror("msgrcv");
			break;
		}
		printf("%ld: %s\n",rec.mytype,rec.mtext);
		
		
		if(0==strcmp(rec.mtext,"quit"))
			break;
		printf("please puts mtext:");
		scanf("%s",rec.mtext);
		rec.mytype=2;
		if(msgsnd(msqid,&rec,sizeof(rec.mtext),0)<0)
		{
			perror("msgsnd");
			return -1;
		}
		if(0==strcmp(rec.mtext,"quit"))
			break;
	}
	
	return 0;
}

 2.

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
int main(int argc, const char *argv[])
{
	key_t key = ftok("./01signal.c", 1);
	int shmid = shmget(key, 32, IPC_CREAT | 0664);
	printf("shmid=%d\n", shmid);
	void *addr = shmat(shmid, NULL, 0);
	int *flag = (int *)addr;
	*flag = 0;
	char *str = (char *)((int *)addr + 1);

	strcpy(str, "123456789");
	while (1)
	{
		int i = 0, j = strlen(str) - 1;
		if (1 == *flag)
		{

			while (i < j)
			{
				str[i] = str[i] + str[j];
				str[j] = str[i] - str[j];
				str[i] = str[i] - str[j];
				i++;
				j--;
			}
			*flag = 0;
		}
	}

	return 0;
}
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
int main(int argc, const char *argv[])
{
	key_t key = ftok("./01signal.c", 1);
	int shmid = shmget(key, 32, IPC_CREAT | 0664);
	printf("shmid=%d\n", shmid);
	void *addr = shmat(shmid, NULL, 0);
	int *flag = (int *)addr;
	char *str = (char *)((int *)addr + 1);
	while (1)
	{
		if (0 == *flag)
		{
			printf("%s\n", str);
			*flag=1;
		}
	}

	return 0;
}

内容概要:本文档详细介绍了基于MATLAB实现的多头长短期记忆网络(MH-LSTM)结合Transformer编码器进行多变量时间序列预测的项目实例。项目旨在通过融合MH-LSTM对时序动态的细致学习和Transformer对全局依赖的捕捉,显著提升多变量时间序列预测的精度和稳定。文档涵盖了从项目背景、目标意义、挑战与解决方案、模型架构及代码示例,到具体的应用领域、部署与应用、未来改进方向等方面的全面内容。项目不仅展示了技术实现细节,还提供了从数据预处理、模型构建与训练到能评估的全流程指导。 适合人群:具备一定编程基础,别是熟悉MATLAB和深度学习基础知识的研发人员、数据科学家以及从事时间序列预测研究的专业人士。 使用场景及目标:①深入理解MH-LSTM与Transformer结合的多变量时间序列预测模型原理;②掌握MATLAB环境下复杂神经网络的搭建、训练及优化技巧;③应用于金融风险管理、智能电网负荷预测、气象预报、交通流量预测、工业设备健康监测、医疗数据分析、供应链需求预测等多个实际场景,以提高预测精度和决策质量。 阅读建议:此资源不仅适用于希望深入了解多变量时间序列预测技术的读者,也适合希望通过MATLAB实现复杂深度学习模型的开发者。建议读者在学习过程中结合提供的代码示例进行实践操作,并关注模型训练中的关键步骤和超参数调优策略,以便更好地应用于实际项目中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值