目录
- msgget
- 函数原型
- 参数
- 返回值
- msgctl
- 函数原型
- 参数
- cmd字段除了公共的四个操作以外,还有自己独立的操作
- IPC_RMID
- IPC_SET
- IPC_STAT
- IPC_INFO
- 返回值
- msgrcv msgsnd
- 描述
- 函数原型
- 参数
- msgsnd
- msgrcv
- 返回值
- msgsnd
- msgrcv
- msgp
msgget
创建消息队列。如果把消息队列看做一个文件的话,那么该函数就相当于open。
函数原型
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
int msgget(key_t key, int msgflg);
参数
第一个参数是key值。
第二个参数的地位用来确定消息队列的访问权限。可以附加参数:
- IPC_CREAT //如果key不存在,则创建*(类似open函数的O_CREAT)*
- IPC_EXCL //如果key存在,则返回失败*(类似open函数的O_EXCL)*
- IPC_NOWAIT //如果需要等待,则直接返回错误
比如:msgid=msgget(key,0666|IPC_CREAT)
返回值
成功执行时,返回消息队列标识符。失败返回-1,errno被设为以下的某个值
- EACCES:指定的消息队列已存在,但调用进程没有权限访问它,而且不拥有CAP_IPC_OWNER权能
- EEXIST:key指定的消息队列已存在,而msgflg中同时指定IPC_CREAT和IPC_EXCL标志
- ENOENT:key指定的消息队列不存在同时msgflg中不指定IPC_CREAT标志
- ENOMEM:需要建立消息队列,但内存不足
- ENOSPC:需要建立消息队列,但已达到系统的限制
msgctl
该函数用来对消息队列的基本属性进行控制、修改。
函数原型
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
int msgctl(int msqid, int cmd, struct msqid_ds *buf);
参数
- msqid为消息队列标识符。
- cmd为执行的控制命令(在ipc.h中定义):
- #define IPC_RMID 0
- #define IPC_SET 1
- #define IPC_STAT 2
- #define IPC_INFO 3
- buf
cmd字段除了公共的四个操作以外,还有自己独立的操作
删除消息队列。从系统中删除给消息队列以及仍在该队列上的所有数据,这种删除立即生效。
仍在使用这一消息队列的其他进程在它们下一次试图对此队列进行操作时,将出错,并返回EIDRM。
此命令只能由如下两种进程执行:
设置消息队列的属性。按照buf指向的结构中的值,来设置此队列的msqid_id结构。
该命令的执行特权与上一个相同。
读取消息队列的属性。取得此队列的msqid_ds结构,并存放在**buf***中。
读取消息队列基本情况。
返回值
成功:IPC_STAT, IPC_SET, and IPC_RMID 返回0
失败:返回-1,并设置 errno
msgrcv msgsnd
这是一对函数,用于消息队列的发送和接收
描述
msgsnd函数用于将新的消息添加到消息队列的尾端。
msgrcv函数用于从消息队列中读取msqid指定的消息
函数原型
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
int msgsnd(int msqid, const void *msgp,size_t msgsz, int msgflg);
ssize_t msgrcv(int msqid, void *msgp, size_t msgsz, long msgtyp,int msgflg);
参数
msgsnd
- msqid:消息队列标识符(由msgget生成)
- msgp:指向用户自定义的缓冲区(msgp)
- msgsz:接收信息的大小。范围在0~系统对消息队列的限制值
- msgflg:指定在达到系统为消息队列限定的界限时应采取的操作。
- IPC_NOWAIT 如果需要等待,则不发送消息并且调用进程立即返回,errno为EAGAIN
- 如果设置为0,则调用进程挂起执行,直到达到系统所规定的最大值为止,并发送消息
msgrcv
-
msqid:消息队列标识符
-
msgp:指向用户自定义的缓冲区(msgp)
-
msgsz:如果收到的消息大于msgsz,并且msgflg&MSG_NOERROR为真,则将该消息截至msgsz字节,并且不发送截断提示
-
msgtyp:用于指定请求的消息类型:
- msgtyp=0:收到的第一条消息,任意类型。
- msgtyp>0:收到的第一条msgtyp类型的消息。
- msgtyp<0:收到的第一条最低类型(小于或等于msgtyp的绝对值)的消息。
-
msgflg:用于指定所需类型的消息不再队列上时的将要采取的操作:
IPC_NOWAIT:如果队列中没有符合条件的消息,则立即返回,而不是阻塞等待消息到达。如果同时设置了这个标志和消息队列中无消息符合接收条件,则 msgrcv
函数会返回 -1
并设置 errno
为 ENOMSG
。
MSG_NOERROR:如果消息长度大于 msgsz
,则截断消息,而不是返回错误。
MSG_EXCEPT:接收队列中除了 msgtyp
指定类型的消息之外的其他消息。
MSG_WAIT:如果没有消息可接收,则阻塞等待,直到有消息到达。
返回值
毋庸置疑,成功0,失败-1。
其他要注意的是,消息队列数据结构(msqid_ds类型)成员的变化:
msgsnd
成功时:
- msg_qnum 以1为增量递增
- msg_lspid 设置为调用进程的pid
- msg_stime 设置为当前时间。
msgrcv
成功时:
- msg_qnum 以1为增量递减
- msg_lrpid 设置为调用进程的pid
- msg_rtime 设置为当前时间。
msgp
该类型需要自己在编程时定义,用于存储消息的内容。
下面给出一个范例,注意,里面的名称随意。
struct msgbuf{long mtype; //消息类型char mtext[1];//数组大小编程时自己指定
};