消息队列
之前学到了进程间通信主要是为了让两个毫不相关的进程之间看到一份公共的资源。
管道提供了进程之间数据流的传输。
消息队列提供了一个从一个进程向另外一个进程发送一块数据的方法。
每个数据块被认为是有类型的,接收者进程接受数据块是可以有不同的类型的。
消息队列的不足:每个消息的最大长度是有上限的,每个消息队列的总的字节数是有上限的,系统上消息队列的总数也是有上限的。
ipc对象数据结构
操作系统内核为每个ipc对象都维护了一个数据结构
在/usr/include/linux/ipc.h中可以查看到:
也可以在/usr/include/linux/msg.h中查看到消息队列的数据结构:
如何创建
首先介绍相关接口函数;
msgget函数:用来创建和获得一个消息队列。
返回值:成功返回一个非负整数,即该消息队列的标识码。失败返回-1.
注意:
这个函数的功能是用来区创建和获得,那么如何区分这两个功能?
参数的不同,决定了函数的功能。
1. IPC_CREAT + IPC_EXCL:
若消息队列已存在,出错返回
若消息队列不存在,则创建一个消息队列并且返回。
2. IPC_CREAT
若消息队列不存在,则创建消息队列然后返回
若消息队列已存在,则返回已存在的消息队列
可以看到该函数中参数有一个key_t key,是某个消息队列的名字,那么如何获得它?用以下函数:用来获得一个key值(是一个有符号整数),失败返回-1.
#include <sys/types.h> #include <sys/ipc.h> key_t ftok(const char *pathname, int proj_id);
msgctl函数:消息队列的控制函数
参数:msgid:由msgget函数返回的消息队列标识码
cmd:是将要采取的动作:
IPC_STAT:把msgid_ds中的数据设置为消息队列的当前关联值
IPC_SET:在进程有足够权限的前提下,把消息队列的当前关联值设置为msgid_ds数据结构中给出的值
IPC_RMID:删除消息队列(这里只使用删除消息队列该参数)
有了创建获得和销毁,下面就要有接收信息和发送消息: