操作系统进程间基于消息队列的通信实验4页

上传人:文库****9 文档编号:170686168 上传时间:2021-03-03 格式:DOC 页数:4 大小:39KB
返回 下载 相关 举报
操作系统进程间基于消息队列的通信实验4页_第1页
第1页 / 共4页
操作系统进程间基于消息队列的通信实验4页_第2页
第2页 / 共4页
操作系统进程间基于消息队列的通信实验4页_第3页
第3页 / 共4页
操作系统进程间基于消息队列的通信实验4页_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

《操作系统进程间基于消息队列的通信实验4页》由会员分享,可在线阅读,更多相关《操作系统进程间基于消息队列的通信实验4页(4页珍藏版)》请在金锄头文库上搜索。

1、操作系统课程实验报告 实习题目进程间基于消息队列的通信指导教师学生姓名学 号日 期实现工具C语言实现环境Linux系统实习内容(功能、目标)实验目的:系统了解linux系统的通信机构IPC ,掌握IPC中消息通信机制,理解消息通信的方法及特征。实验内容:编写一段程序,同时父进程创建两个子进程p1和p2;并使子进程p1与子进程p2通过消息队列相互发送消息(字节)。实验要求:()掌握系统调用msgget()、msgsnd()、msgrev()、msgctl()的使用方法及其功能,理解消息通信原理;()系统理解linux 的三种通信机制。实现的思想、方法和技术(含数据结构、算法)一、 消息机制提供四

2、个系统调用:1. msgget返回一个消息描述字msgqid,msgqid指定一个消息队列以便其他三个系统调用使用。2. msgsnd和msgrcv分别表示发送和接收一消息。Msgsnd(msgqid,msgp,msgsz,msgflg)中的msgqid是msgget返回消息队列描述符:msgp是用户缓冲区指针,msgsz是消息正文的长度,msgflg是同步标示,规定msgqid发送消息是发送完毕后返回还是不等发送完立即返回。3. 系统调用msgrev比msgsnd多一个参数msgtyp,它规定接收消息的类型。msgtyp=0时,表示接收与msgqid相关联的消息队列上的第一个消息; msgt

3、yp0时,表示接收msgqid相关联消息队列上第一个消息,而 msgtyp0时,则表示接收小于或等于msgtyp绝对值的最低类型的第一个消息。4. msgctl用来设置和返回与msgqid相关联的参数选择项,以及用来删除描述符的选择项。主要代码注释#include#include#include#include#include#includestring.h#define MSGKEY 75struct msgformlong mtype;char mtext512;int msgqid;struct msgform msg1,msg2;int p1,p2,pud1,pid2,*pint1,*

4、pint2,i;while(p1=fork()=-1);if(p1=0)msgqid=magget (MSGKEY,0777); strcpy(msg1.mtext,Hello!);msg1=mtype=1; msgsnd(msgqid,&msg1,sizeof(512),0); msqrcv(msgqid,&msg,512,pid,0); printf(client:receivefrom pid%dn,msg1.mtext); else while(p2=fork()=-1); if(p2=0) msgqid=msgget(MSGKEY,0777|IPC_CREAT); msgrcv (m

5、sgqid,&msg2,512,1,0); printf(server:receive from pid%dn,msg2.mtext); msg2=mtype=7; strcpy(msg1.mtext,byebye!); msgsnd(msgqid,&msg2,256,0); exit(0); cleanup() msgctl (msgqid,IPC_RMID,0); exit();/消息的格式/消息的类型、正文长度/创建进程p1/建立消息队列若存在返回消息描述字/将正文放入/指定消息的类型/往msgqid发送消息msg1/接收来自服务进程的消息/输出正文的内容/创建进程p2/建立与顾客程序相同的消息队列/接收来自顾客进程的消息/放在接收方/服务者进程接收到的信息/当前接收进程的pid放到正文/发送应答消息结果分析(含实现中出错原因分析)思考:1、消息通信与管道通信有何区别答:消息通信是用于所有进程之间通信的,管道通信只能用于家族进程之间的通信。2、为什么unix中要增设IPC核心软件包?答: IPC有三个组成部分:1) 消息用于进程之间传递分类的格式化数据2) 共享存储方式可使得不同进程通过共享彼此的空间而达到互相对共享区操作和数据通信的目的。3) 信号量机制用于通信进程之间的同步控制,信号量通常与共享存储器一起使 指导教师评语、评分 评分: 指导教师: 年 月 日

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号