消息队列

原创 2012年03月27日 12:40:57

消息队列就是消息的一个链表,它允许一个或多个进程向它写消息,一个或多个进程从中读消息。具有一定的FIFO的特性,但是可实现消息的随即查询。这些消息存在于内核中,由“队列ID”来标识。

消息队列的实现包括创建和打开队列、添加消息、读取消息和控制消息队列这四种操作。

msgget:创建和打开队列,其消息数量受系统限制。

 int msgget (key_t key, int flag)

   key:返回新的或已有队列的IDIPC_PRIVATE

 

msgsnd:添加消息,将消息添加到消息队列尾部。

 int msgsnd (int msqid, struct msgbuf *msgp, size_t msgsz, int flag)

  msqid是消息队列的队列ID

 msgp是消息内容所在的缓冲区;

 msgsz是消息的大小;

 msgflg是标志,IPC_NOWAIT若消息并没有立交发送而调用进程会立即返回。

 struct msgbuf

    {

         long mtype; /* type of message */

   char mtext[1]; /* message text */

};

 

msgrcv:读取消息,从消息队列中取走消息。

 int msgrcv (int msqid, struct msgbuf *msgp, size_t msgsz,long msgtyp, int flag)

  msqid是消息队列的引用标识符;

 msgp是接收到的消息将要存放的缓冲区;

 msgsz是消息的大小;

 msgtyp是期望接收的消息类型;

 msgflg是标志。

 

msgctl:控制消息队列。

 int msgctl (int msqid, int cmd, struct msqid_ds *buf)

  msqid是消息队列的引用标识符;

  cmd是执行命令;

  buf是一个缓冲区。

cmd参数指定对于由msqid规定的队列要执行的命令:

n IPC_STAT取此队列的msqid_ds结构,并将其存放在buf指向的结构中。

n IPC_SET按由buf指向的结构中的值,设置与此队列相关的结构中的下列四个字段:msg_perm.uidmsg_perm.gid、msg_perm;modemsg_qbytes。此命令只能由下列两种进程执行:一种是其有效用户ID等于msg_perm.cuidmsg_perm.uid;另一种是具有超级用户特权的进程。只有超级用户才能增加msg_qbytes的值。

n IPC_RMID从系统中删除该消息队列以及仍在该队列上的所有数据。这种删除立即生效。仍在使用这一消息队列的其他进程在它们下一次试图对此队列进行操作时,将出错返回EIDRM

 

例:设计两个程序,要求用消息队列实现聊天程序。增加结束字符,比如最后输入“end”后结束进程。设消息队列的key为1234。

send.c文件

server.c文件

运行结果:

相关文章推荐

消息队列

概述       消息队列是内核地址空间中的内部链表,用于进程间的通信。   消息队列的打开或创建       通过键值获得消息队列的描述字 int msgget(key_t key, ...

Qt 应用Redis 实现消息队列

  • 2017年11月03日 14:50
  • 38KB
  • 下载

RabbitMQ入门与消息队列模式详解

RabbitMQ提供了6种模式,分别是HelloWorld,Work Queue,Publish/Subscribe,Routing,Topics,RPC Request/reply,本文详细讲述了前...

各种消息队列技术对比分享

  • 2017年11月01日 11:02
  • 1.34MB
  • 下载

kafka消息队列集群安装说明

  • 2017年11月10日 14:17
  • 24KB
  • 下载

消息队列使用的四种场景介绍

消息队列中间件是分布式系统中重要的组件,主要解决应用耦合,异步消息,流量削锋等问题 实现高性能,高可用,可伸缩和最终一致性架构 使用较多的消息队列有ActiveMQ,RabbitMQ,ZeroMQ,K...

RabbitMQ.Client消息队列动态库

  • 2017年10月28日 15:11
  • 131KB
  • 下载

用Redis做一个简单的消息队列

  • 2017年08月21日 22:55
  • 1KB
  • 下载

进程间通信(IPC)之消息队列

漫谈进程间通信之消息队列,进程通信家族中不可或缺的一员。交流学习,共同进步。...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:消息队列
举报原因:
原因补充:

(最多只允许输入30个字)