day8--消息队列

本文详细介绍了在C语言中使用消息队列的发送端(包括申请key、创建/打开队列、发送消息)和接收端(接收消息、控制消息队列)的步骤,以及关键函数如msgget、msgsnd、msgrcv和msgctl的用法。
摘要由CSDN通过智能技术生成

消息队列的使用

发送端

1.申请key

2.打开/创建消息队列   msgget

3.向消息队列发生消息 msgsnd

打开/创建消息队列

#include <sys/ipc.h>

#include <sys/msg.h>

int msgget(key_t key, int msgflg);

成功时返回消息队列的id,失败时返回EOF

key和消息队列关联的key     IPC_PRIVATE或ftok

msgflg  标志位 IPC_CREAT|0666   IPC_CREAT作用没有时创建,有的话就打开

消息的发送

#include <sys/ipc.h>

#include <sys/msg.h>

int msgsnd(int msgid, const void* msgp, size_t size, int msgflg);

成功时返回0,失败时返回-1

msgid    消息队列id

msgp     消息缓冲区地址

size               消息正文长度

msgflg    标志位0或IPC_NOWAIT

msgflg:为0时,当消息队列满时,msgsnd将会阻塞,直到消息能写进消息队列

               为IPC_NOWAIT时,当消息队列已满的时候,msgsnd函数不等待立即返回

消息格式:

typedef struct {

       long msg_type;

       char buf[128];

}msgT;

注意:消息结构必须有long类型的msg_type字段,表示消息的类型

           消息长度不包括首类型long

coding

#include <stdio.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <sys/types.h>
#include <string.h>

typedef struct {	//消息的格式
	long msg_type;	//这个long型不能缺少
	char buf[128];	//消息占的字节数
}msgT;

#define MSGLEN (sizeof(msgT) - sizeof(long))	//消息正文的长度

int main(int argc, const char *argv[])
{
	key_t key;
	int ret;
	int msgid;
	msgT msg;
	key = ftok(".",100);	//申请key,第一个参数是真实存在的文件名,第二个参数在0-255之间
	if(key < 0) {
		perror("ftok");
		return 0;
	}

	msgid = msgget(key, IPC_CREAT | 0666);	//打开或创建消息队列
	if(msgid < 0) {
		perror("msgget");
		return 0;
	}
	
	msg.msg_type = 1;	//给结构体赋值
	strcpy(msg.buf, "I am type 1");

	ret = msgsnd(msgid, &msg, MSGLEN, 0);	//发送消息
	if(ret < 0) {
		perror("msgsnd");
		return 0;
	}

	return 0;
}

接收端

1.打开/创建消息队列   msgget

2.从消息队列接收消息 msgrcv

3.控制(删除)消息队列    msgctl

消息的接收

#include <sys/ipc.h>

#include <sys/msg.h>

int msgrcv(int msgid, void* msgp, size_t size, long msgtype, int msgflg);

成功时返回收到消息队列的长度,失败时返回-1

msgid     消息队列id

msgp      消息缓冲区地址

size         指定接收的消息长度

msgtype 指定接收的消息类型

msgflg    标志位

msgtype参数详情

msgtype = 0:收到的第一条消息,可以是任意类型

msgtype > 0:收到的第一条msg_type类型的消息

       msgtype < 0:接收类型等于或小于msgtype绝对值的第一个消息

              例如:如果msgtype = -4,只接受类型是1、2、3、4的消息

msgflg参数详情

       0:阻塞式接收消息

       IPC_NOWAIT:如果没有返回条件的消息调用立即返回,此时错误码为ENOMSG

       IPC_EXCEPT:与msgtype配合使用返回队列中第一个类型不为msgtype的消息

消息队列的控制

#include <sys/ipc.h>

#include <sys/msg.h>

int msgctl(int msgid, int cmd, struct msqid_ds* buf);

成功时返回0,失败时返回-1

msgid    消息队列id

cmd       要执行的操作 IPC_STAT / IPC_SET / IPC_RMID(删除)

buf        存放消息队列属性的地址

coding

#include <stdio.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <sys/types.h>
#include <string.h>

typedef struct {	//消息的格式
	long msg_type;	//这个long型不能缺少
	char buf[128];	//消息占的字节数
}msgT;

#define MSGLEN (sizeof(msgT) - sizeof(long))	//消息正文的长度

int main(int argc, const char *argv[])
{
	key_t key;
	int ret;
	int msgid;
	msgT msg;
	key = ftok(".",100);	//申请key,第一个参数是真实存在的文件名,第二个参数在0-255之间
	if(key < 0) {
		perror("ftok");
		return 0;
	}

	msgid = msgget(key, IPC_CREAT | 0666);	//打开或创建消息队列
	if(msgid < 0) {
		perror("msgget");
		return 0;
	}
	
	while(1) {
		ret = msgrcv(msgid, &msg, MSGLEN, 0, 0);	//接收消息
		if(ret < 0) {
			perror("msgsnd");
			return 0;
		}
		printf("Get msg type=%ld,buf=%s\n",msg.msg_type,msg.buf);//打印接收的消息
	}
	return 0;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@Cabbage

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值