消息队列
消息队列是将消息按队列的方式组织成的链表,每个消息都是其中的一个节点。
消息队列的运行方式与命名管道非常相似。欲与其他进程通信的进程只要将消息发送到消息队列中,目的进程就从消息队列中读取需要的消息。需要注意的是,消息队列的长度以及每个消息的大小都是有限制的。
Linux系统提供的消息队列操作函数主要有以下几个:
int msgget(key_t key,int msgflg);
int msgsnd(int msqid, const void *msgptr, int msgsz,int msgflg);
int msgrcv(int msqid, void *msgptr, int msgsz, long msgtyp, int msgflg);
int msgctl(int msqid, int cmd, struct msqid_ds *buf);
msgget()函数与信号量的semget()函数相似,作用是创建一个消息队列。参数key是一个键值,可由用户设定也可通过ftok()函数获得。Msgflg参数设置的是一些标志位,可以是IPC_CREAT、IPC_EXCL、IPC_NOWAIT中的一个或者他们的组合。创建成功则返回消息队列ID;否则返回-1。
Msgsnd()函数的作用是将消息发送到消息队列中去。Msqid为消息队列ID