资源描述:
《实验九进程通信-消息的发送与接收》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、实验九进程通信消息的发送与接收实验实验目的1、了解什么是消息2、熟悉消息传送的机理实验内容消息的创建、发送和接收。使用系统调用msgget(),msgsnd(),msgrev(),及msgctl()编制一长度为1k的消息发送和接收的程序。实验指导一、什么是消息消息(message)是一个格式化的口J变长的信息单元。消息机制允许由一个进程给其它任意的进程发送一个消息。当一个进程收到多个消息吋,可将它们排成一个消息队列。消息使用二种重耍的数据结构:一是消息首部,其中记录了一些与消息有关的信息,如消息数据
2、的字节数;二个消息队列头表,其每一表项是作为一个消息队列的消息头,记录了消息队列的有关信息。1、消息机制的数据结构(1)消息首部记录一些与消息有关的信息,如消息的类型、大小、指向消息数据区的指针、消息队列的链接指针等。(2)消息队列头表其每一项作为一个消息队列的消息头,记录了消息队列的有关信息如指向消息队列中第一个消息和指向最后一个消息的指针、队列中消息的数目、队列中消息数据的总字节数、队列所允许消息数据的最大字节总数,述冇最近一次执行发送操作的进程标识符和时间、最近一次执行接收操作的进程标识符和时
3、间等。2、消息队列的描述符UNIX屮,每一个消息队列都有一个称为关键字(key)的名字,是由用户指定的;消息队列右一消息队列描述符,其作用与用户文件描述符一样,也是为了方便用户和系统对消息队列的访问。二、涉及的系统调用1・msgget()创建一个消息,获得一个消息的描述符。核心将搜索消息队列头表,确定是否有指定名字的消息队列。若无,核心将分配一新的消息队列头,并对它进行初始化,然后给用户返回一个消息队列描述符,否则它只是检查消息队列的许可权便返回。系统调用格式:msgqid=msgget(key,f
4、lag)该函数使用头文件如下:#include#include#include参数定义intmsgget(key,flag)key_tkey;intflag;其中:kly是用户指定的消息队列的名字;flag是用户设置的标志和访问方式。如IPC_CREAT10400是否该队列已被创建。无则创建,是则打开;IPC_EXCL10400是否该队列的创建应是互斥的。msgqid是该系统调用返冋的描述符,失败则返冋・1。2・msgsnd()发
5、送一消息。向指定的消息队列发送一个消息,并将该消息链接到该消息队列的尾部。系统调用格式:msgsnd(msgqid5msgp,size,flag)该函数使用头文件如下:#include#include#include参数定义:intmsgsnd(msgqid,msgp,size,flag)Iintmsgqid,size,flag;structmsgbuf*msgp;其中msgqid是返冋消息队列的描述符;msgp是指向用户消息缓冲
6、区的一个结构体指针。缓冲区中包括消息类型和消息正文,即{longmtype;/*消息类型*/charmtext[];/*消息的文木*/}size指示由msgp指向的数据结构屮字符数组的长度;即消息的长度。这个数组的最大值由MSG・MAX()系统可调用参数來确定。flag规定当核心用尽内部缓冲空间吋应执行的动作:进程是等待,还是立即返回。若在标志flag中未设置IPC_NOWAIT位,则当该消息队列屮的字节数超过最大值吋,或系统范围的消息数超过某一最大值时,调用msgsnd进程睡眠。若是设置IPC_N
7、OWAIT,则在此情况下,msgsnd立即返回。对于msgsnd(),核心须完成以卜•工作:(1)对消息队列的描述符和许可权及消息长度等进行检查。若合法才继续执行,否则返冋;(2)核心为消息分配消息数据区。将用户消息缓冲区中的消息正文,拷贝到消息数据区;(3)分配消息首部,并将它链入消息队列的末尾。在消息首部中须填写消息类型、消息大小和指向消息数据区的指针等数据;(4)修改消息队列头中的数据,如队列中的消息数、字节总数等。最后,唤醒等待消息的进程。3・msgrcv()接受一消息。从指定的消息队列中接
8、收指定类型的消息。系统调用格式:msgrcv(msgqid,msgp,size,type,flag)本函数使用的头文恥如下:#include#includevsys/ipc.h>#include参数定义:intmsgrcv(msgqid,msgp,size,type,flag)intmsgqid,size,flag;structmsgbuf*msgp;longtype;其中,msgqid,msgp,size,flag与m