首先在我的MAC OSX上试了一下虽然有_POSIX_MESSAGE_PASSING的宏定义,但是用gcc编译会提示没有mqueue.h头文件,先放一边。在Ubuntu上使用正常,不过POSIX消息队列通过ipcs命令是看不到的,需要通过如下方式进行查看:

mount -t mqueue none /mnt
ls -al /mnt

ls列出的文件即为程序中创建的POSIX消息队列,消息队列的名称需要以“/”开头否则会提示参数非法。通过cat查看这个文件可以知道这个队列的一些参数如:

hgf@ubuntu:~/ipc$ cat /mnt/testmq

QSIZE: NOTIFY: SIGNO: NOTIFY_PID:

编译代码时需要加上-lrt参数,即连接Posix.1 realtime库,

基本操作API

mqd_t mq_open(const char* name, int oflag, ... /* mode_t mode, struct mq_attr attr */);

int mq_close(mqd_t mqdes);

int mq_unlink(const char* name);

int mq_getattr(mqd_t mqdes, struct mq_attr* attr);

int mq_setattr(mqd_t mqdes, struct mq_attr* attr, struct mq_attr* oattr);

int mq_send(mqd_t mqdes, const char* buf, size_t len, unsigned int prior);

int mq_receive(mqd_t mqdes, const char* buf, size_t len, unsigned int* priop);

mqcreate.c (gcc mqcreate.c -lrt -o mqcreate)

#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <mqueue.h>
#include <unistd.h>
#include <getopt.h> struct mq_attr attr; int main(int argc, char** argv) {
char opt; char* MQ_NAME = "/testmq"; int OPEN_MODE = O_RDWR | O_CREAT;
int FILE_MODE = S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP; while((opt = getopt(argc, argv, "en:m:z:")) != -) {
switch(opt) {
case 'e':
OPEN_MODE |= O_EXCL;
break;
case 'm':
attr.mq_maxmsg = atol(optarg);
break;
case 'z':
attr.mq_msgsize = atol(optarg);
break;
case 'n':
MQ_NAME = optarg;
break;
}
} printf("msg queue name:%s\nmsg max size: %ld\nmsg per size: %ld\n",
MQ_NAME, attr.mq_maxmsg, attr.mq_msgsize); struct mq_attr* attrarg = NULL;
if (attr.mq_maxmsg != ) {
attrarg = &attr;
} mqd_t mq = mq_open(MQ_NAME, OPEN_MODE, FILE_MODE, attrarg); if (mq < ) {
perror("message queue create failed:");
return ;
} return ;
}

mqunlink.c (gcc mqunlink.c -lrt -o mqunlink)

#include <stdio.h>
#include <stdlib.h> #include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <mqueue.h> int main(int argc, char** argv) {
char* MQ_NAME = "/testmq"; if (argc > ) {
MQ_NAME = argv[];
} int res = mq_unlink(MQ_NAME); if (res < ) {
perror("close message queue:");
} return ;
}

mqgetattr.c

#include <stdio.h>
#include <stdlib.h> #include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <mqueue.h> int main(int argc, char** argv) {
char* name = "/testmq"; if (argc > ) {
name = argv[];
} mqd_t mq = mq_open(name, O_RDONLY); if (mq < ) {
perror("open message queue failed:");
return ;
} struct mq_attr attr; mq_getattr(mq, &attr); printf("max #msgs = %ld, max #bytes/msg = %ld, #current = %ld\n",
attr.mq_maxmsg, attr.mq_msgsize, attr.mq_curmsgs
); int res = mq_close(mq); if (res != ) {
perror("close message queue failed:");
}
return ;
}

mqsend.c

#include <stdio.h>
#include <stdlib.h>
#include <string.h> #include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <mqueue.h> int main(int argc, char** argv) {
mqd_t mqd;
void *ptr;
size_t len;
unsigned int prio; if (argc != ) {
printf("%s msg_queue_name message priority\n", argv[]);
return -;
} mqd = mq_open(argv[], O_WRONLY); if (mqd < ) {
perror("open message queue failed");
return -;
} len = strlen(argv[]) + ; ptr = malloc(len); prio= atoi(argv[]); strcpy(ptr, argv[]); int res = mq_send(mqd, ptr, len, prio); if (res != ) {
perror("send msg faild");
return -;
} return ;
}

mqreceive.c

#include <stdio.h>
#include <stdlib.h> #include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <mqueue.h>
#include <getopt.h> int main(int argc, char** argv) { char opt; char* queue = "/testmq"; int FILE_MODE = O_RDONLY; while ((opt = getopt(argc, argv, "xn:")) != -) {
switch (opt) {
case 'n':
queue = optarg;
break;
case 'b':
FILE_MODE |= O_NONBLOCK;
break;
}
} mqd_t mqd = mq_open(queue, FILE_MODE); if (mqd < ) {
perror("open message queue failed");
return -;
} struct mq_attr attr;
char* buffer = NULL;
int prio; mq_getattr(mqd, &attr);
buffer = malloc(attr.mq_msgsize + ); for(;;) {
int res = mq_receive(mqd, buffer, attr.mq_msgsize, &prio);
if (res < ) {
perror("read msg fail");
return;
} printf("read msg size:%u, msg(%s), prio:%d\n", res, buffer, prio);
if (FILE_MODE & O_NONBLOCK) {
sleep();
printf(".");
}
}
return ;
}

UNIX IPC: POSIX 消息队列的更多相关文章

  1. UNIX IPC: POSIX 消息队列 与 信号

    POSIX消息队列可以注册空队列有消息到达时所触发的信号,而信号触发对应的信号处理函数. 下面是一份基本的消息队列和信号处理结合的代码(修改自UNIX网络编程:进程间通信) #include < ...

  2. Linux IPC POSIX 消息队列

    模型: #include<mqueue.h> #include <sys/stat.h> #include <fcntl.h> mq_open() //创建/获取消 ...

  3. Unix IPC之Posix消息队列(1)

    部分参考:http://www.cnblogs.com/Anker/archive/2013/01/04/2843832.html IPC对象的持续性:http://book.51cto.com/ar ...

  4. IPC通信:Posix消息队列

    IPC通信:Posix消息队列 消息队列可以认为是一个链表.进程(线程)可以往里写消息,也可以从里面取出消息.一个进程可以往某个消息队列里写消息,然后终止,另一个进程随时可以从消息队列里取走这些消息. ...

  5. Linux IPC实践(7) --Posix消息队列

    1. 创建/获取一个消息队列 #include <fcntl.h> /* For O_* constants */ #include <sys/stat.h> /* For m ...

  6. Linux进程间通信(IPC)编程实践(十二)Posix消息队列--基本API的使用

    posix消息队列与system v消息队列的区别: (1)对posix消息队列的读总是返回最高优先级的最早消息,对system v消息队列的读则能够返回随意指定优先级的消息. (2)当往一个空队列放 ...

  7. Linux环境编程之IPC进程间通信(五):Posix消息队列1

    对于管道和FIFO来说.必须应该先有读取者存在.否则先有写入者是没有意义的. 而消息队列则不同,它是一个消息链表,有足够写权限的线程可往别的队列中放置消息,有足够读权限的线程可从队列中取走消息.每一个 ...

  8. 进程间通信--POSIX消息队列

    相关函数: mqd_t mq_open(const char *name, int oflag); mqd_t mq_send(mqd_t mqdes, const char *msg_ptr, si ...

  9. [转]Linux进程通信之POSIX消息队列

    进程间的消息队列可以用这个实现,学习了下. http://blog.csdn.net/anonymalias/article/details/9799645?utm_source=tuicool&am ...

随机推荐

  1. nginx实现动静分离--附nginx配置文件详解

    转自http://www.cnblogs.com/1214804270hacker/p/9299462.html 一.认识访问静态资源与访问动态资源的区别 静态资源:指存储在硬盘内的数据,固定的数据, ...

  2. 谷歌将对欧洲 Android 设备制造商收取其应用服务费用

    简评:欧盟就谷歌违反了<反垄断法>开出天价罚单,导致谷歌运营生态被打破,为了配合这一裁决,谷歌将调整其运营模式.欧盟似乎赢了,而这最后买单的却是消费者. 今年七月份,谷歌要求 Androi ...

  3. oracle创建表空间、用户、权限

    原链接:https://www.cnblogs.com/wxm-bk/p/6510654.html oracle 创建临时表空间/表空间,用户及授权   1:创建临时表空间 create tempor ...

  4. leetcode-867-Transpose Matrix(矩阵由按行存储变成按列存储)

    题目描述: Given a matrix A, return the transpose of A. The transpose of a matrix is the matrix flipped o ...

  5. 图的最短路径---弗洛伊德(Floyd)算法浅析

    算法介绍 和Dijkstra算法一样,Floyd算法也是为了解决寻找给定的加权图中顶点间最短路径的算法.不同的是,Floyd可以用来解决"多源最短路径"的问题. 算法思路 算法需要 ...

  6. Ubuntu下增加eclipse菜单图标并配置java path(解决点击图标不能启动eclipse的问题)

    Ubuntu下增加eclipse菜单图标 Ubuntu的菜单图标在/usr/share/applications目录下. 1. 在/usr/share/applications目录下新建eclipse ...

  7. Jupyter notebook用法

    参考官网文档:https://jupyter-notebook.readthedocs.io/en/stable/public_server.html 0.介绍jupyter notebook (此前 ...

  8. CSS01--概述与选择器

    CSS:Cascading Style Sheets,层叠样式表.我们之前已经说过,HTML解决的是网页内容(结构)的问题,而CSS立足于网页的表现方面的问题,则样式定义如何显示HTML标签,js负责 ...

  9. net 反编译神器

    文章地址:https://www.cnblogs.com/sheng-jie/p/10168411.html dnSpy官网下载  分享链接 .net core源码导航 https://www.cnb ...

  10. Ubuntu 16.04防火墙

    防火墙(ufw) 说明:简单版本的防火墙,底层依赖于iptables. 安装:sudo apt-get install ufw 查看状态:sudo ufw status 开启/关闭:sudo ufw ...