场景:
进程A向消息队列写消息,而进程B则从消息队列读消息。
消息队列和之前的管道不同,消息队列是相对独立于进程的,它不需要进程自己来提供同步方法。消息队列里面有消息就可以读。
读取消息实例:msg_rcv.c
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
struct my_msg_st {
long int my_msg_type;
char some_text[BUFSIZ];
};
int main(int argc,char **argv)
{
int running = 1;
int msgid;
struct my_msg_st some_data;
long int msg_to_receive = 0;
msgid = msgget((key_t)1234,0666 | IPC_CREAT);
if(msgid == -1){
fprintf(stderr,"Msgget failed!\n");
exit(-1);
}
while(running){
if(msgrcv(msgid,(void *)&some_data,BUFSIZ,msg_to_receive,0) == -1){
fprintf(stderr,"Msgrcv failed!\n");
exit(-1);
}
printf("You wrote: %s",some_data.some_text);
if(strncmp(some_data.some_text,"end",3) == 0){
running = 0;
}
}
if(msgctl(msgid,IPC_RMID,0) == -1

本文介绍了Unix/Linux环境下使用消息队列进行进程间通信的应用实例,包括读取和写入消息的详细代码示例。消息队列作为独立于进程的数据结构,提供了内置的同步机制。读者可以通过先运行写消息的进程,随后运行读消息的进程来观察效果,通过`ipcs`和`ipcrm`命令查看和管理IPC资源。
最低0.47元/天 解锁文章
981

被折叠的 条评论
为什么被折叠?



