- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
 - 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
 - 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
 
                        查看更多
                        
                    
                实验7基于消息队列的进程通讯1、实验目的利用消息队列实现进程之.doc
                    实验7 基于消息队列的进程通讯
实验目的:
利用消息队列实现进程之间的通讯
2、实验内容:
2.1实验内容:
要求写2个程序,一个发消息,一个收消息。消息内容可以自己定义。要求调试通过程序,并分析结果
2.2 实验相关函数
利用消息队列实现进程之间通讯的步骤:
第1步,消息队列的实现包括创建或打开消息队列,使用的函数是msgget(),创建的消息队列的数量会受到系统消息队列数量的限制
第2步,添加消息、读取消息。添加消息使用的函数是msgsnd()函数,它把消息添加到已打开的消息队列末尾;读取消息使用的函数是msgrcv(),它把消息从消息队列中取走,与FIFO不同的是,这里可以指定取走某一条消息;
第3步,还可以控制消息队列,使用的函数是msgctl(),它可以完成多项功能,其中可以用它删去消息队列。
创建或打开消息队列函数语法:
消息发送函数语法:
消息读取函数语法:
消息控制函数语法:
2.3 参考代码
  
/* msgrcv.c */
#include sys/types.h
#include sys/ipc.h
#include sys/msg.h
#include stdio.h
#include stdlib.h
#include unistd.h
#include string.h
#define  BUFFER_SIZE		512
struct message
{
	long msg_type;
	char msg_text[BUFFER_SIZE];
};
int main()
{
	int qid;
	key_t key;
	struct message msg;	
	/*根据不同的路径和关键表示产生标准的key*/
	if ((key = ftok(., a)) == -1)
	{
		perror(ftok);
		exit(1);
	}
	
	/*创建消息队列*/
	if ((qid = msgget(key, IPC_CREAT|0666)) == -1)
	{
		perror(msgget);
		exit(1);
	}
	printf(Open queue %d\n, qid);
	
	do
	{
		/*读取消息队列*/
		memset(msg.msg_text, 0, BUFFER_SIZE);
		if (msgrcv(qid, (void*)msg, BUFFER_SIZE, 0, 0)  0)
		{
			perror(msgrcv);
			exit(1);
		}
		printf(The message from process %d : %s, msg.msg_type, msg.msg_text);	
		
	} while(strncmp(msg.msg_text, quit, 4));
	
	
	/*从系统内核中移走消息队列 */
	if ((msgctl(qid, IPC_RMID, NULL))  0)
	{
		perror(msgctl);
		exit(1);
	}
	
	exit(0);
}
/* msgsnd.c */
#include sys/types.h
#include sys/ipc.h
#include sys/msg.h
#include stdio.h
#include stdlib.h
#include unistd.h
#include string.h
#define  BUFFER_SIZE		512
struct message
{
	long msg_type;
	char msg_text[BUFFER_SIZE];
};
int main()
{
	int qid;
	key_t key;
	struct message msg;
	
	/*根据不同的路径和关键表示产生标准的key*/
	if ((key = ftok(., a)) == -1)
	{
		perror(ftok);
		exit(1);
	}
	
	/*创建消息队列*/
	if ((qid = msgget(key, IPC_CREAT|0666)) == -1)
	{
		perror(msgget);
		exit(1);
	}
	printf(Open queue %d\n,qid);
	
	while(1)
	{
		printf(Enter some message to the queue(enter quit to exit):);
		if ((fgets(msg.msg_text, BUFFER_SIZE, stdin)) == NULL)
		{
			puts(no message);
			exit(1);
		}
		
	
                
原创力文档
                        
                                    

文档评论(0)