Posix消息队列.docVIP

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

Linux3+1暑期学习总结三(Posix消息队列) ---王晶晶 一,消息队列简介: 消息队列可以看作是一个消息连表。它具有随内核的持续性,即当使用该消息队列的进程结束,或者已关闭该消息队列,该队列中的消息不会随之消失,只有在内核重新初始化,即计算机重启之后才会消失,因此称为随内核的持续性,这点也是与管道和FIFO的区别。消息队列的另一个特性是,在某一个进程往消息队列写消息之前不需要另外某个进程在该消息队列上等待消息的到达,即不会像管道个FIFO那样,如果往管道或者FIFO中些数据时,如果没有一个进程已经将读端打开,那么写操作会被阻塞。当然,如果从消息队列读取数据时,消息队列为空是会阻塞的。 每个消息都是一条记录,它有发送者赋予一个优先权,值越大优先级越高。 下图为一个消息队列可能的布局: 头消息 mq_maxmsg mq_msgsize 下一个消息 优先级=30 长度=1 数据 下一个消息 优先级=20 长度=2 数据 NULL 优先级=10 长度=3 数据 该链表的头中含有当前队列的两个属性:队列中允许的最大消息数,每个消息的最大大小。 二,相关函数解释: mq_open 所在头文件:#includemqueue.h 函数原型:mqd_t mq_open(const char *name, int 0flag,... mode_t mode, struct mq_attr *attr); 函数功能:创建消息队列。 参数说明:name为消息队列的名字,根据消息队列的规则,为了更好的可移植性,该名字必须以‘/’开头,创建一个消息队列的时候无须路径,给出名字就好,其存放位置可有自己指定(创建前后都可以,下面会讲到)。 oflag:为O_RDONLY(只读),O_WRONLY(只写),O_RDWR(可读可写)之一,可能安位或上O_CREATE,O_EXCL(当消息已存在时,返回EEXIST错误到errno中),O_NONBLOCK(设置非阻塞)。 mode和attr参数是可选,但是当实际操作是创建一个新队列时,即O_CREATE已指定,且要求创建的消息队列不存在,mode和attr参数是需要的。 mode:表示创建消息对列的权限。由 S_IRUSR,S_IWUSR,S_IXUSR,S_IRGRP,S_IWGRP,S_IXGRP,S_IROTH,S_IWOTH, S_IXOTH相或组成或者写成0777(表示rwxrwxrwx)等用八进制表示也可以。 attr:在linux内核源代码中struct_mqattr定义???源代码如下: 存放消息队列的属性。其中mq_flags为0,表示阻塞,为O_NONBLOCK为非阻塞。 函数返回值:在内核源代码中mqd_t类型的定义如下: typedef __kernel_mqd_t mqd_t; typedef int __kernel_mqd_t; 若创建成功则返回消息队列的描述符,否则返回-1。 2.mq_close函数: 所在头文件:#includemqueue.h 函数原型:int mq_close(mqd_t mqdes); 函数功能:关闭已打开的消息队列,关闭后调用进程不可以再使用该描述符,但其消息队列并没有被删除。一个进程终止时,它的所有打开着的消息队列都关闭,就像调用了mq_close一样。 参数说明:mqdes为消息队列的描述符,即消息队列创建成功后的返回值。 返回值:成功返回0,失败返回-1。 3.mq_unlink函数 所在头文件:#includemqueue.h 函数原型:int mq_unlink(const char *name); 函数作用:从系统中删除名为name的消息队列。但删除的只是我们可以在系统中看见的文件的名字,但文件本身并没有被从磁盘上删除,除非该名称是文件的最后一个链接,并且该文件已关闭,才会将该文件真正从磁盘上删除。即如果某前该详细队列的文件还在其他进程中打开,那么不会将其从磁盘上删除,又或者这是最后一个链接,但它还为关闭,即未执行ma_close操作,或打开它的进程为结束就执行mq_unlink,它也不会从磁盘上删除。 函数的参数:消息队列的名称,以‘/’开始。 函数的返回值:成功返回0,出错返回-1。 4.mq_getattr函数 所在头文件:#includemqueue.h 函数原型:int mq_getattr(mqd_t mqdes, struct mq_attr *attr); 函数功能:获取mqdes指的消息队列的属性,存放到attr结构体中。 参数说明:mqdes为消息队列描述符,attr为上面解释的存

文档评论(0)

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

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

1亿VIP精品文档

相关文档