这会是一系列文章,讲解的内容也很简单,文章的目的是让自己的知识固话和文档化,以备自己不时的复习,同时也希望能够给予初学者一些帮助。
前面的文章有介绍了如何利用管道进行进程间的通信,但是那只适合比较简单的场景,发送一些简单的通知,我只在 Android 的 Framework 源码中见过这么一回。而 Linux 下 IPC 的手段有很多,今天介绍的消息队列就是其中的一种。
什么是消息队列?
顾名思义,消息队列,首先得是一个队列,这个队列里面存放了许许多多的消息。
---msg----|---msg----|---msg----|---msg---|
特别的是,这个队列是一个内核链表。
什么意思是,进程间通过消息队列进行通信的时候,操作系统内核站了出来,做了一个中间人,它维护了消息队列,并提供了如下操作。
- 创建消息队列
- 添加消息
- 读取消息
进程间要传递数据只要按照相应的格式封装好,然后发送到消息队列当中就好了。
下面对于这些特性开始一一讲解。
消息队列中的消息
消息在实际运行当中是一种数据结构,叫做消息缓冲结