操作系统实验消息队列.docVIP

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统实验消息队列.doc

实验六 消息队列 一.1.消息队列可以认为是一个消息链表。有足够写权限的进程可向队列中放置消息,有足够读权限的进程可以从队列中取走消息。每个消息是一个记录,它有发送者赋予一个优先级。在某个进程向一个队列写入消息之前,并不需要另外某个进程在该队列上等待消息的到达。 2.实现消息队列的相关系统调用函数: (1)msgget(): 如果希望创建一个新的消息队列,或者希望存取一个已经存在的消息队列,你可以使用系统调用msgget()。 系统调用:msgget(); 原型:intmsgget(key_t key,int msgflg); 返回值:如果成功,返回消息队列标识符 如果失败,则返回-1:errno=EACCESS(权限不允许) EEXIST(队列已经存在,无法创建) EIDRM(队列标志为删除) ENOENT(队列不存在) ENOMEM(创建队列时内存不够) ENOSPC(超出最大队列限制) 第一个参数是关键字值(通常是由ftok()返回的)。然后此关键字值将会和其他已经存在于系统内核中的关键字值比较。这时,打开和存取操作是和第二个参数msgflg中的内容相关的。 第二个参数的取值: IPC_CREAT:如果内核中没有此队列,则创建它。 IPC_EXCL: 当和IPC_CREAT一起使用时,如果队列已经存在,则失败。 如果单独使用IPC_CREAT,则msgget()要么返回一个新创建的消息队列的标识符,要么返回具有相同关键字值的队列的标识符。如果 IPC_EXCL和IPC_CREAT一起使用,则msgget()要么创建一个新的消息队列,要么如果队列已经存在则返回一个失败值-1。 IPC_EXCL单独使用是没有用处的。 (2)系统调用msgsnd() 一旦我们得到了队列标识符,我们就可以在队列上执行我们希望的操作了。如果想要往队列中发送一条消息,你可以使用系统调用msgsnd(): 系统调用:msgsnd(); 原型:intmsgsnd(int msqid,struct msgbuf*msgp,int msgsz,int msgflg); 返回值:如果成功,0。 如果失败,-1:errno=EAGAIN(队列已满,并且使用了IPC_NOWAIT) EACCES(没有写的权限) EFAULT(msgp地址无效) EIDRM(消息队列已经删除) EINTR(当等待写操作时,收到一个信号) EINVAL(无效的消息队列标识符,非正数的消息类型,或者无效的消息长度) ENOMEM(没有足够的内存复制消息缓冲区) 系统调用msgsnd()的第一个参数是消息队列标识符,它是由系统调用msgget返回的。第二个参数是msgp,是指向消息缓冲区的指针。第三个参数msgsz中包含的是消息的字节大小,但不包括消息类型的长度(4个字节)。参数msgflg可以设置为0(此时为忽略此参数),或者使用IPC_NOWAIT。 如果消息队列已满,那么此消息则不会写入到消息队列中,控制将返回到调用进程中。如果没有指明,调用进程将会挂起,直到消息可以写入到队列中。 (3)msgrcv() 系统调用:msgrcv(); 原型:intmsgrcv(int msqid,struct msgbuf *msgp,int msgsz,long mtype,int msgflg); 返回值:如果成功,则返回复制到消息缓冲区的字节数。 如果失败,则返回-1:errno=E2BIG(消息的长度大于msgsz,没有MSG_NOERROR) EACCES(没有读的权限) EFAULT(msgp指向的地址是无效的) EIDRM(队列已经被删除) EINTR(被信号中断) EINVAL(msgqid无效,或者msgsz小于0) ENOMSG(使用IPC_NOWAIT,同时队列中的消息无法满足要求) 第一个参数用来指定将要读取消息的队列。第二个参数代表要存储消息的消息缓冲区的地址。第三个参数是消息缓冲区的长度,不包括mtype的长度,它可以按照如下的方法计算: msgsz=sizeof(struct mymsgbuf)-sizeof(long); 第四个参数是要从消息队列中读取的消息的类型。如果此参数的值为0,那么队列中最长时间的一条消息将返回,而不论其类型是什么。如果调用中使用了IPC_NOWAIT作为标志,那么

文档评论(0)

docindoc + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档