linux IPC机制之msg q学习

回顾一下,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所占用,这种情况怎么办?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值