Linux的消息队列

消息队列是两个进程之间传递二进制块数据的一种简单有效的方式。每个数据块都有一个特定的类型,接收方可以根据类型来有选择的接收数据,不一定像管道和命名管道那样必须先进先出的方式接收。

Linux System V的消息队列的API定义在 <sys/msg.h>, 文件包括四个系统调用:msgget(),msgsnd(), msgrcv(), msgctl();

msgget系统调用

msgget系统调用创建一个消息队列,或者获取一个现有的消息队列。

#include <sys/msg.h>

int msgget(key_t key, int msgflg);

msgflg和semget的参数相同。
如果msgget()成功返一个正整数,它是消息队列的标识符。失败返回-1,并修改errno。

msgsnd系统调用

msgsnd把一条消息添加到消息队列中。

int msgsnd(int msqid, const void* msg_ptr, size_t msg_sz, int msgflg);

msg_ptr表示指向一个准备发送的消息,消息必须被定义为如下的类型。

struct msgbuf {
  long mtype;   // 消息类型
  char mtex[512];  // 消息数据
}

msgrcv 系统调用

msgrcv从消息队列中获取数据。

    int msgrcv(int msqid, void* msg_ptr,
               size_t msg_sz, long int msg_type, int msgflg)

msgctl 系统调用

msgctl用于控制消息队列的某些属性。

    int msgctl(int msgid, int commond, struct msqid_ds* buf);

在操作系统system V IPC进程间通信方式都使用一个全局唯一的键值key 来描述一个共享资源,当程序调用semget, shmget 或者msgge,就创建这些共享资源的一个实例。
Linux 提供了ipcs命令,来观察当前系统上拥有哪些共享资源的实例。

ipcs.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容