消息队列通讯编程

1.基本概念

消息队列就是一个消息的链表。而一条消息则可看做是一个记录,具有特定的格式

进程可以按照一定的规则添加新消息;另一些进程则可以从消息队列中读走消息。

2.函数学习

创建消息队列

函数名: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

3.综合实例

/* 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();
		}
	}
}
时间: 2024-10-17 11:15:24

消息队列通讯编程的相关文章

linux消息队列应用编程

消息队列:  消息队列提供了一个从一个进程向另外一个进程发送一块数据的方法   每个数据块都被认为是有一个类型,接收者进程接收的数据块可以有不同的类型值   消息队列也有管道一样的不足,就是每个消息的最大长度是有上限的(MSGMAX),每个消息队列的总的字节数是有上限的(MSGMNB),系统上消息队列的总数也有一个上限(MSGMNI) 对比管道和消息: 管道:流管道        消息:有边界 先进先出              可以后进入.先出来 消息大小三大限制 cat /proc/sys/

linux 进程间消息队列通讯

转自:http://blog.csdn.net/lifan5/article/details/7588529 http://www.cnblogs.com/kunhu/p/3608589.html 前言: 消息队列是内核地址空间中的内部链表,通过linux内核在各个进程之间传递内容,消息顺序地发送到消息队列中,并且以几种不同的方式 从队列中获取,每个消息队列可以用IPC标识符唯一的进行标识,内核中的消息队列是通过IPC的标识符来区别的,不同的消息队列之间是 相互独立的,每个消息队列中的消息又构成

LInux进程间通信之消息队列编程实例

本文主要通过消息队列的编程实例来加深对消息队列的理解. 一.消息队列之创建 创建一个消息队列,需要用到一个函数: #include<sys/types.h> #include<sys/ipc.h> #include<sys/msg.h> int msgget(key_t key,int msgflg); key:需要调用ftok函数来获取. msgflg:IPC_CREAT,不存在则创建,存在则返回已有的qid. IPC_CREAT|IPC_EXCL,不存在则创建,存在

boost进程间通信经常使用开发一篇全(消息队列,共享内存,信号)

本文概要: 敏捷开发大家想必知道并且评价甚高,缩短开发周期,提高开发质量.将大project独立为不同的小app开发,整个开发过程,程序可用可測,所以提高了总体的质量.基于这样的开发模式和开发理念,进程间通信必定是童鞋们必掌握技能之中的一个了,而boost库是众多库中平台支持性非常好,效果非常高之中的一个.做嵌入式或者server等应用的人肯定有所涉及.本文以手冊方式讲述boost共享内存,信号,以及消息队列的编程方式.非常easy,列出最经常使用使用方法,供大家拷贝直接使用.本文出自CSDN-

WCF分布式开发步步为赢(13):WCF服务离线操作与消息队列MSMQ

之前曾经写过一个关于MSMQ消息队列的文章:WCF分布式开发必备知识(1):MSMQ消息队列 ,当时的目的也是用它来作为学习WCF 消息队列MSMQ编程的基础文章.在那篇文章里,我们详细介绍了MSMQ消息队列的基本概念.安装.部署.开发.调试等相关问题.今天我们来学习WCF分布式开发步步为赢(13):WCF服务离线操作与消息队列MSMQ.在WCF框架下使用MSMQ消息队列服务编程.  这里我会给出一个使用WCF MSMQ实现离线请求的DEMO示例程序. 全文结构是:[1]MSMQ基本概念[2]W

UNIX环境下的消息队列

消息队列和共享内存一样,也是一种IPC对象.消息队列其实就是消息的链表,每一则消息都是用户自己的结构体.服务端这边创建消息队列,客户端这边打开消息队列,两个进程就可以进行通信.创建和打开消息队列使用函数msgget,发送消息到消息队列使用函数msgsnd,从消息队列中取出消息使用函数msgrcv,通信完毕后删除消息队列使用函数msgctl.这四个函数就是消息队列通信编程主要用到的函数,man命令就可以看到他们的详细信息. 前面说到消息是用户自己构造的结构体,其实这个结构体也是有讲究的,这是lin

编程开发消息队列解析

一.消息队列概述 消息队列中间件是分布式系统中重要的组件,主要解决应用耦合,异步消息,流量削锋等问题.实现高性能,高可用,可伸缩和最终一致性架构.是大型分布式系统不可缺少的中间件. 目前在生产环境,使用较多的消息队列有ActiveMQ,RabbitMQ,ZeroMQ,Kafka,MetaMQ,RocketMQ等. 二.消息队列应用场景 以下介绍消息队列在实际应用中常用的使用场景.异步处理,应用解耦,流量削锋和消息通讯四个场景. 2.1异步处理 场景说明:用户注册后,需要发注册邮件和注册短信.传统

【进程编程】——msg进程间的消息队列通信

           [进程编程]--msg进程间的消息队列通信 消息队列就像一个链表,先进先出,就像排队打饭,先到先买!键值 用来获取消息队列的描述字,我感觉就像是一个定位标识符! 函数一     key_t ftok(char *pathname,char proj)返回的是一个键值------>创建队列之前一定要获取这个键值!proj:项目名,不为零即可 打开.创建函数二     int msgget(key_t key,int msgflg) //看见没,这里是要求键值的. key:键值

Linux系统编程——进程间通信:消息队列

消息队列提供了一种在两个不相关的进程之间传递数据的简单高效的方法,其特点如下: 1)消息队列可以实现消息的随机查询.消息不一定要以先进先出的次序读取,编程时可以按消息的类型读取. 2)消息队列允许一个或多个进程向它写入或者读取消息. 3)与无名管道.命名管道一样,从消息队列中读出消息,消息队列中对应的数据都会被删除. 4)每个消息队列都有消息队列标识符,消息队列的标识符在整个系统中是唯一的. 5)消息队列是消息的链表,存放在内存中,由内核维护.只有内核重启或人工删除消息队列时,该消息队列才会被删