【回眸】技术干货——Linux 内核 (十三)进程间通讯 之 消息队列
前言
这个系列的上一篇介绍了进程间通讯关于管道相关的内容及代码实例,本章要介绍关于消息队列相关的内容.
消息队列交互图示
函数原型
#include <sys/msg.h> #include <sys/ipc.h> //创建 or 打开队列 成功返回队列ID,失败返回-1 int msgget(key_t key,int flag); //创建新队列的条件:没有与键值key相对应的消息队列,且flag中含有IPC_CREAT的标志位 //or key参数为IPC_PRIVATE //添加消息:成功返回 0,失败返回-1 int msgsnd (int msqid,const void *ptr,size_t size,int flag); //读取消息:成功返回 消息数据的长度,失败返回-1 int msgrcv(int msqid,void *ptr,size_t size,long type,int flag); //控制消息队列:成功返回 0,失败返回-1 int msgctl(int msqid,int cmd,struct msqid_ds *buf);
消息队列API函数应用
msgGet.c
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <string.h>
struct msgBuf
{
long mtype;
char mtext[128];
};
int main(){
struct msgBuf sendBuf = {888,"msg from que pjy "};
int msgID = msgget(0x1234,IPC_CREAT|0777);
if(msgID == -1){
printf("get que failure\n");
}
msgsnd(msgID,&sendBuf,strlen(sendBuf.mtext),0);
return 0;
}
msgSend.c
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
struct msgBuf
{
long mtype;
char mtext[128];
};
int main(){
struct msgBuf readBuf;
//获取队列
int msgID = msgget(0x1234,IPC_CREAT|0777);
if(msgID == -1)
{
printf("get que failure !\n");
}
msgrcv(msgID,&readBuf,sizeof(readBuf.mtext),888,0);
printf("read from que: %s \n",readBuf.mtext);
return 0;
}
运行结果展示
后记碎碎念
Linux内核是一个系列,可以点击专栏查看同系列的其他文章,希望能帮到屏幕前的每一位应届生往届生,该博文最初发表在CSDN上。
#校招求职有谈薪空间吗##找工作前vs找工作后的心路变化##职场中你干过哪些“蠢”事##26届秋招投递记录##央国企投递记录#应届生必学实用物联网技术 文章被收录于专栏
本专栏助应届生从物联网小白成长为企业争抢的技术人才,聚焦三大核心技术:传感器应用(环境监测)、嵌入式开发(STM32/Arduino)、通信协议(LoRa/NB-IoT/MQTT),配合10+实战项目(如智能温湿度监控系统)积累项目经验。覆盖智能硬件、工业物联网、智能家居领域岗位需求,解析企业招聘技术重点与面试题,帮电子、计算机、自动化等专业学生构建知识体系,提前锁定名企Offer!

