标签:linux编程 进程间通信 ipc 消息队列通讯 linux c
消息队列就是一个消息的链表。而一条消息则可看做是一个记录,具有特定的格式
进程可以按照一定的规则添加新消息;另一些进程则可以从消息队列中读走消息。
创建消息队列
函数名:msgget
函数原型:int msgget(key_t key,int msgflg)
函数功能:打开或创建消息队列
头文件:<sys/types.h> <sys/ipc.h><sys/msg.h>
返回值:成功:返回消息队列的id 失败:-1
参数说明:key:键值 msgflg:打开标志IPC_CREAT标明新创建一个消息队列
写消息
函数名:msgsnd
函数原型:int msgsnd(int msqid,const void *msqp,size_t msgsz,int msgflg)
函数功能:发送消息到消息队列
头文件:<sys/types.h> <sys/ipc.h> <sys/msg.h>
返回值:失败:-1 成功:0
参数说明:msqid:消息队列的id
msgp:指向要发送的消息
msgsz:消息的长度
msgflg:标志
读消息
函数名:msgrcv
函数原型:ssize_t msgrcv(int msqid,void *msgp,size_t msgsz,long msgtyp,int msgflg)
函数功能:从消息队列中接收消息
头文件:<sys/types.h> <sys/ipc.h> <sys/msg.h>
返回值:失败:-1 成功:实际接收到的消息长度
参数说明:msqid:消息队列的id
msgp:存放取出的消息
msgsz:希望取到消息的最大长度
msgtyp:消息的类型 取值0 则忽略类型 大于0取消息队列中类型等于msgtyp的第一条消息 小与0取类型比msgtyp的绝对值要小与等于的消息,如果有多条消息满足,则取类型最小的
msgflg:标志
删除消息队列
函数名:msgctl
函数原型:int msgctl(int msgqid,int cmd,struct msgqid_ds *buf)
函数功能:控制消息队列
头文件:<sys/types.h> <sys/ipc.h> <sys/msg.h>
返回值:成功:0 失败:-1
参数说明:msgqid:消息队列的id
cmd:对消息队列的操作命令
IPC_RMID删除消息队列
buf:获取内核中msqid_ds
/* send.c */
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
struct msgt
{
long msgtype;
char msgtext[1024];
};
void main()
{
int msqid;
int msg_type;
char str[256];
struct msgt msgs;
//创建消息队列
msqid = msgget(1024,IPC_CREAT);
while(1)
{
printf("please input message type,0 for quit");
//获取消息类型
scanf("%d",&msg_type);
//如果用户输入的消息了类型为0,则退出
if(msg_type == 0)
break;
//获取消息数据
printf("please input message content\n");
scanf("%s",str);
msgs.msgtype = msg_type;
strcpy(msgs.msgtext,str);
//发送消息
msgsnd(msqid,&msgs,sizeof(struct msgt),0);
}
//删除消息队列
msgctl(msqid,IPC_RMID,0);
}/* receive.c */
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
int msqid;
struct msgt
{
long msgtype;
char msgtext[1024];
};
void childprocess()
{
struct msgt msgs;
while(1)
{
//接收消息队列
msgrcv(msqid,&msgs,sizeof(struct msgt),0,0);
//打印消息数据
printf("msg text:%s\n",msgs.msgtext);
}
return;
}
void main()
{
int i;
int pid;
//打开消息队列
msqid = msgget(1024,IPC_EXCL);
//创建3个子进程
for(i=0; i<3; i++)
{
pid = fork();
if(pid<0)
{
printf("creat child process error\n");
}
else if(pid == 0)
{
childprocess();
}
}
}
标签:linux编程 进程间通信 ipc 消息队列通讯 linux c
原文地址:http://blog.csdn.net/zhuwenfeng215/article/details/45535903