回顾一下,linux系统的IPC机制有:
pipe/FIFO/signal/temp file/semaphore/shared memeory以及message queue等。
本文要讲的是其中的一种IPC机制:message queue。
message queue就是两个进程之间创建的一个消息队列用于发送和接受消息。
发送者和接收者通过message queue通信时,无需同时运行。
message queue的使用很简单,下面将简单介绍message queue的使用。
1. 创建一个新的message queue,
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
int msgget(key_t key, int msgflg);
通常这样:
msqid = msgget(key, IPC_CREAT | IPC_EXCL | 0666);
表示要创建一个新的message queque,如果queue已经存在则返回一个EEXIST的值。
2. 发送和接收来自于message queue的message,
int msgsnd(int msgid, const void *msgp, size_t msgsz, int msgflg);
ssize_t msgrcv(int msgid, vpod *msgp, size_t msgsz, long msgtyp, int msgflg);
其中msgp的格式是由用户自定义的,通常格式如下:
struct msgbuf {
long mtype;
char mtext[1];
};
以上可以看到,两个进程之间通过message queue进行通信需要依赖于msgget创建的message queue的msgid。
这个msgid应该是和key关联的。
如果进程A创建这个message queue,那么进程B如何才能拿到这个message queue的msgid呢?
msgid = msgget(key, IPC_CREAT | 0666);
进程B通过以上方式获得的msgid无法保证是进程A所创建的message queue的msgid。
所以问题就是:
key可能已经被别的message queue所占用,这种情况怎么办?