【Linux】进程间通信 -- System V 消息队列

前言

上节Linux学习,我们学习了System V的共享内存,本节我们学习System V 的另一种通信方式 --- 消息队列

文章目录

  • 前言
  • [一. 消息队列的原理](#一. 消息队列的原理)
  • 二.创建消息队列
  • [二. 查看消息队列](#二. 查看消息队列)
  • [三. 删除消息队列](#三. 删除消息队列)
  • [四. 读写数据](#四. 读写数据)
  • 结束语

一. 消息队列的原理

消息队列的本质同共享内存一样,也是在内存中有一个又一个的数据块,但是操作系统对其先描述再组织的方式不同,是将这些数据块像队列的元素那样管理,并且标识是哪个进程创建

二.创建消息队列

创建消息队列的函数是msgget()

同共享内存的参数和返回值一样。

  1. 第一个参数是用来标识队列,操作系统通过一系列算法生成的key值

    ftok函数生成key值,用pathname和proj_id生成一个冲突较小的key值

  2. 第二个参数是创建方式,有两种创建方式:
    IPC_CREAT:没有就创建,有则返回msqid,队列id
    IPC_CREAT | IPC_EXCL:没有就创建,有则报错

    还可以 | 上消息队列的权限

  3. 返回值是msqid,队列id

二. 查看消息队列

查看消息队列的命令 ipcs -q

key:消息队列的key值
msqid:消息队列的队列id
owner:创建该消息队列的用户
perms:权限
used-bytes:使用的字节数
messages:消息数

三. 删除消息队列

指令删除ipcrm -q 消息队列id
函数删除msgctl()

具体操作同共享内存的shmctl()

msqid :消息队列的id
cmd :具体操作,使用位图的方式传入,删除是IPC_RMID
buf :其他操作,比如IPC_STAT获取消息队列属性需要传入的消息队列的结构体

四. 读写数据

写数据 的函数是msgsnd()
读数据 的函数是msgrcv()

msqid:消息队列的队列id
msgp:读写数据使用的结构体
msgsz:读写数据的大小
msgflg:一般为0(当消息队列满时,会阻塞,等到可以再写入消息为止)
msgtyp:标识是哪个进程写入的数据。优先接收某进程的第一个消息

读写数据的结构体 如下

mtype:标识该数据块是哪个进程写入
mtext:柔性数组,存储读写数据

结束语

感谢你的阅读

如果觉得本篇文章对你有所帮助的话,不妨点个赞支持一下博主,拜托啦,这对我真的很重要。

相关推荐
半夏知半秋19 分钟前
rust学习-rust中的格式化打印
服务器·开发语言·后端·学习·rust
mcharleylei20 分钟前
Centos 安装docker
linux·docker·centos
handsomestWei25 分钟前
springboot使用tomcat浅析
spring boot·后端·tomcat
SmallBambooCode34 分钟前
【Flask】在Flask应用中使用Flask-Limiter进行简单CC攻击防御
后端·python·flask
Xiao Xiangζั͡ޓއއ1 小时前
程序诗篇里的灵动笔触:指针绘就数据的梦幻蓝图<1>
c语言·开发语言·程序人生·学习方法·改行学it
汪款学嵌入式1 小时前
C语言常用字符串处理函数
c语言
jerry-891 小时前
系统安全及应用
linux·运维·服务器
AiFlutter2 小时前
在AlarmLinux系统中安装KeyDB
linux·运维·服务器
左手の明天2 小时前
【C/C++】C++中使用vector存储并遍历数据
c语言·开发语言·c++
.晚街听风~2 小时前
【无标题】
c语言