`

进程间通信学习笔记四(消息队列)

 
阅读更多

消息队列


信号能够传送的信息量有限
管道只能传送无格式的字节流
消息队列就是一个消息链表,消息可以看作是一个记录,具有特定的格式


消息队列的分类:
posix(可移植的操作系统接口)消息队列
系统v消息队列:是随内核持续的,只有在内核重起或者人工删除时,该消息队列才会被删除


键值
每个消息队列都在系统范围内对应唯一的键值,也是获得消息队列描述字的方法


返回文件名对应的键值
#include <sys/types.h>
#include <sys/ipc.h>
key_t ftok(char *pathname,char proj)
pathname:文件名
proj:项目名(不为0即可)




打开、创建
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
int msgget(key_t key,int msgflg)
key:键值,由ftok获得(设为ipc_private时会创建一个新的消息队列)
msgflg:标志位
标志位常用取值:
IPC_CREATE 创建新的消息队列
IPC_EXCL 与create一同使用,如果要创建的消息队列已经存在,返回错误
IPC_NOWAIT 读写消息队列要求无法得到满足时,不阻塞
返回值:与健值key相对应的消息队列描述字


示例代码如下:
int open_queue(key_t keyval){
int qid;
if((qid=msgget(keyval,IPC_CREAT))==-1){
return (-1);
}
return (qid);
}


发送消息
#include <sys/types.h>
#incldue <sys/ipc.h>
#incldue <sys/msg.h>
int msgsnd(int msqid,sturct msgbuf *msgp,int msgsz,int msgflg)
msqid:消息对列的id
msgp: 存放消息的结构
msgsz:消息数据长度
msgflg:发送标志,IPC_NOWAIT指明在消息队列没有足够空间容纳要发送的消息时,
msgsnd是否等待




消息格式:
struct msgbuf{
int mtype;/*消息类型>0*/
char mtext[1];/*消息数据的首地址*/
};






接收消息
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
int msgrcv(int msqid,struct msgbuf *msgp,int msgsz,long msgtyp,int msgflg)
从消息队列中读取一个msgtyp类型的消息,并把消息存储在msgp指向的msgbuf结
构中,成功读取后,队列中的这条消息将被删除


示例代码如下:
int read_message(int qid,long type,struct mymsgbuf *qbuf){
int result,length;
/*去掉type类型的长度*/
length=sizeof(struct mymsgbuf)-sizeof(long);
if((result=msgrcv(qid,qbuf,length,type,0))==-1){
return (-1);
}
return (result);
}




示列代码如下:
#include <sys/types.h>
#include <sys/msg.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct msg_buf{
int mtype;
char data[255];
};


int main(){
key_t key;
int msgid;
int ret;
struct msg_buf msgbuf;

/*消息的创建*/
key=ftok("/home/retacn/tmp/app/2",'a');
printf("key=[%x]\n",key);
/*打开消息队列*/
msgid=msgget(key,IPC_CREAT|0666);/*通过文件对应*/

if(msgid==-1){
printf("create error\n");
return -1;
}

/*消息的发送*/
msgbuf.mtype=getpid();
strcpy(msgbuf.data,"test ha");
ret=msgsnd(msgid,&msgbuf,sizeof(msgbuf.data),IPC_NOWAIT);
if(ret==-1){
printf("send message err\n");
return -1;
}
/*消息的接收*/
memset(&msgbuf,0,sizeof(msgbuf));
ret=msgrcv(msgid,&msgbuf,sizeof(msgbuf.data),getpid(),IPC_NOWAIT);
if(ret==-1){
printf("recv message err\n");
return -1;
}
printf("recv msg=[%s]\n",msgbuf.data);
}



执行结果如下:
[root@localhost app]# gcc msg.c -o msg
[root@localhost app]# ./msg
key=[6105a185]
recv msg=[test ha]

分享到:
评论

相关推荐

    MFC教程lesson 17-进程间通信.rar

    在IT领域,MFC(Microsoft Foundation ...学习完这个教程后,开发者应该能够熟练地在MFC应用中实现进程间通信,从而提升程序的扩展性和协作性。对于想要深入理解和应用MFC的程序员来说,这是一个不可错过的章节。

    学习笔记信号量和进程间通信

    本学习笔记将深入探讨信号量和进程间通信的相关概念、原理以及实际应用。 首先,让我们理解什么是进程。进程是程序执行的实例,拥有独立的内存空间和系统资源,它们在操作系统中并行运行。在多进程环境中,为了协调...

    消息队列activemq学习笔记

    ### 消息队列Activemq学习笔记 #### MQ入门概述 消息队列(Message Queue,简称MQ)是一种用于在应用程序之间传递数据的机制。它允许应用之间通过发送消息进行通信,而无需直接调用对方。 ##### 前言:MQ=消息...

    《ORANGE’S:一个操作系统的实现》读书笔记(二十四)进程间通信(二)文章代码

    消息队列是另一种进程间通信的方式,它提供了一种有序的消息传递机制。在ORANGE’S系统中,每个进程都可以发送消息到队列,而其他进程则可以从队列中接收消息。这种通信方式可以确保消息的顺序性,并且避免了竞争...

    23.1.1-消息队列的概念和函数 FreeRTOS 项目 FreeRTOS学习笔记 FreeRTOS移植 FreeRTOS开源项 目 FreeRTOS面试题汇总FreeRTOS项目实战F103.md

    在嵌入式系统开发中,消息队列是一种非常重要的进程间通信(IPC)机制,特别是在实时操作系统FreeRTOS中。消息队列允许任务(线程)之间或中断与任务之间交换信息。消息队列的概念类似于现实生活中的排队等候,每个...

    liunx中的消息队列学笔记。

    ### Linux中的消息队列学习笔记 #### 消息队列概念 消息队列是一种进程间通信方式,允许发送包含一定格式的数据消息。消息队列中的消息由消息类型和消息文本组成,消息类型是一个整数值,它用于区分不同类型的事件...

    ucos-ii学习笔记

    uCOS-II 的消息队列是一种进程间通信机制,允许不同的任务之间exchange 数据。消息队列由一个数组组成,每个元素存储一个消息指针。消息队列的实现主要涉及到三个步骤:创建消息队列、发送消息和接收消息。 创建...

    《ORANGE’S:一个操作系统的实现》读书笔记(二十五)进程间通信(三)文章代码

    在操作系统设计中,进程间通信(IPC,Inter-Process Communication)是至关重要的组成部分,它允许不同进程之间交换数据和同步状态。《ORANGE’S:一个操作系统的实现》这本书深入浅出地介绍了操作系统的设计与实现...

    消息中间件学习笔记.zip

    消息中间件是分布式系统中用于实现进程间通信的一种技术。它在软件系统中扮演着重要的角色,尤其是在需要处理高并发和异步处理的场景中。消息中间件的主要作用包括解耦系统组件、提高系统的可伸缩性、提供可靠的消息...

    rabbitmq学习笔记和软件和插件

    **RabbitMQ学习笔记与软件插件详解** RabbitMQ是一种广泛应用的消息中间件,它基于AMQP(Advanced Message Queuing Protocol)协议,提供可靠的消息传递服务。在分布式系统中,RabbitMQ扮演着数据交换中心的角色,...

    Linux 进程 线程学习笔记

    Linux提供了多种机制来实现进程间通信(IPC),包括信号、管道、消息队列、共享内存和信号量等。 #### 线程管理 在Linux中,线程的创建和管理主要通过`pthread`库实现,其中`pthread_create()`用于创建新线程,`...

    RocketMQ学习笔记 .pdf

    RocketMQ学习笔记主要涵盖了消息队列(MQ)的相关知识,内容深入浅出,不仅包含理论知识,还融入了实战案例和源码分析,适用于希望掌握RocketMQ的开发者。 首先,RocketMQ是一个分布式、开源的消息中间件,它起源于...

    操作系统学习笔记(三)1

    本文主要探讨了操作系统中的进程与线程,以及进程间通信的基础概念。 一、进程 进程是操作系统中运行程序的实例,它包含了程序的代码、数据、状态信息等。一个进程在某一时刻可能处于运行、就绪、阻塞三种状态之一...

    VC++深入学习笔记

    #### Lesson17: 进程间通信 - 进程之间通过管道、共享内存等方式交换数据。 #### Lesson18: ActiveX控件 - 创建和使用ActiveX控件,增强应用程序的功能。 #### Lesson19: 动态链接库DLL - 创建和使用动态链接库...

    VC++深入详解学习笔记

    笔记涵盖了从Windows程序内部运行机制到MFC程序框架、消息映射机制、DC获取、菜单编程、对话框编程、图形绘制、文件操作、文档和串行化、网络编程、多线程和简单聊天室制作、线程同步与异步套接字编程、进程间通信、...

    操作系统_学习笔记_进程管理_教学辅助_1741864631.zip

    进程通信是指进程间交换信息的过程,常见的进程通信方式有管道、消息队列、共享内存等。死锁是指两个或两个以上的进程因争夺资源而无限等待的现象,解决死锁的策略包括预防死锁、避免死锁、检测死锁和解除死锁等。 ...

    跨进程自学资料与笔记

    1. 进程间通信(IPC, Inter-Process Communication):这是跨进程的核心,包括管道、共享内存、消息队列、套接字、命名管道等多种方式。每种方式都有其适用场景和优缺点,需要根据实际需求选择。 2. 同步与互斥:当...

    哈工大操作系统读书笔记4(第四周)

    第四周的学习内容通常会涉及进程管理、线程概念以及进程间通信等相关知识点。 一、进程管理 在操作系统中,进程是程序的一次执行过程,它是系统进行资源分配和调度的基本单位。第四周可能会讲解以下几个方面的内容...

    linux下C语言开发笔记整理

    进程间通信(IPC)允许独立的进程交换数据,常见的IPC方法包括管道(pipes)、消息队列、共享内存等。 ### Unix/Linux系统的网络编程 网络编程是Linux下C语言开发的核心内容之一,涉及套接字编程,用于实现网络...

Global site tag (gtag.js) - Google Analytics