Linux 多进程通信开发(四): 消息队列

本文详细介绍了Linux下消息队列的工作原理和使用方法,包括创建消息队列、发送与接收消息,以及消息队列的属性管理。通过实例代码展示了如何在进程间通过消息队列进行通信,强调其相对于管道的优势和灵活性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这会是一系列文章,讲解的内容也很简单,文章的目的是让自己的知识固话和文档化,以备自己不时的复习,同时也希望能够给予初学者一些帮助。

前面的文章有介绍了如何利用管道进行进程间的通信,但是那只适合比较简单的场景,发送一些简单的通知,我只在 Android 的 Framework 源码中见过这么一回。而 Linux 下 IPC 的手段有很多,今天介绍的消息队列就是其中的一种。

什么是消息队列?

顾名思义,消息队列,首先得是一个队列,这个队列里面存放了许许多多的消息。

---msg----|---msg----|---msg----|---msg---|

特别的是,这个队列是一个内核链表。

什么意思是,进程间通过消息队列进行通信的时候,操作系统内核站了出来,做了一个中间人,它维护了消息队列,并提供了如下操作。

  • 创建消息队列
  • 添加消息
  • 读取消息

进程间要传递数据只要按照相应的格式封装好,然后发送到消息队列当中就好了。

下面对于这些特性开始一一讲解。

消息队列中的消息

消息在实际运行当中是一种数据结构,叫做消息缓冲结构体,在 linux 下有如下定义。


#include <linux/msg.h>

struct msgbuf {
	__kernel_long_t mtype; 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

frank909

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

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

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

打赏作者

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

抵扣说明:

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

余额充值