一、什么是消息队列?
IPC:inter-project communication(进程间的通信)
在linux中IPC有三种:消息队列、共性内存、信号量。
消息队列实际就是一个消息的列表,进程可以在消息队列中添加消息和的读取消息。消息队列具有FIFO的特性,具有无名管道与有名管道各自的优势,可以支持任意两个进程的进程间通讯。想了解管道的可以看我前面的博客。
在linux终端下可以使用 ipcs -q或者ipcs 来查看现有的消息队列。

下面的我们来看一下有关消息队列的函数。
二、消息队列的函数
1.消息队列的创建函数
函数头文件 #include <sys/types.h>#include <sys/ipc.h>#include <sys/msg.h>函数原型 int msgget(key_t key, int msgflg);函数功能 获取System V消息队列标识符函数参数key:由ftok函数合成msgflg:消息队列标志IPC_CREAT 创建标志IPC_EXCL 如果消息队列存在,则报错, errno设置为EEXIST权限控制标志函数返回值 成功:返回消息队列id失败:返回-1,并设置errno
消息队列的创建函数返回的类型是一个int 类型,一个id号,如果要在这个消息队列发送或者接收消息,就需要使用这个id号。当然我们可以创建多个消息队列,因为消息队列的大小是有限的。
在创建这个函数的时候需要先使用fotk()函数,得到一个key_t类型的值,fotk()函数使用来创建一个IPC,包括后面的共享内存、信号量,都需要使用先fotk()函数,不了解的fotk()函数没关系,后面有示例。
2.消息队列的删除
函数头文件 #include <sys/types.h>