一、使用消息队列完成两个进程间相互通信
1.c:
#include <myhead.h>
//消息结构体
typedef struct
{
long msgtype;
char data[1024];
}Msg_ds;
#define SIZE sizeof(Msg_ds)-sizeof(long) //正文大小
int main(int argc, const char *argv[])
{
//创建key值
key_t key;
if((key = ftok("/",'k')) == -1)
{
perror("ftok error");
return -1;
}
//创建消息队列
int msgid;
if((msgid = msgget(key,IPC_CREAT|0664)) == -1)
{
perror("msgget error");
return -1;
}
pid_t pid;
pid=fork();
if(pid < 0)
{
perror("fork error");
return -1;
}else if(pid == 0)
{
while(1)
{
Msg_ds msg1;
if(msgrcv(msgid,&msg1,SIZE,200,0) == -1)
{
perror("msgrcv error");
return -1;
}
if(strcmp(msg1.data,"quit") == 0)
{
break;
}
printf("rcv:%s\n",msg1.data);
}
}else{
while(1)
{
//向消息队列中发送数据
Msg_ds msg = {.msgtype = 100};
printf("请输入消息内容:");
fgets(msg.data,sizeof(msg.data),stdin);
msg.data[strlen(msg.data)-1]='\0';
//将消息发送到消息队列中
if(msgsnd(msgid,&msg,SIZE,0) == -1)
{
perror("msgsnd error");
return -1;
}
if(strcmp(msg.data,"quit") == 0)
{
break;
}
}
}
return 0;
}
2.c:
#include <myhead.h>
//消息结构体
typedef struct
{
long msgtype;
char data[1024];
}Msg_ds;
#define SIZE sizeof(Msg_ds)-sizeof(long) //正文大小
int main(int argc, const char *argv[])
{
//创建key值
key_t key;
if((key = ftok("/",'k')) == -1)
{
perror("ftok error");
return -1;
}
//创建消息队列
int msgid;
if((msgid = msgget(key,IPC_CREAT|0664)) == -1)
{
perror("msgget error");
return -1;
}
pid_t pid;
pid=fork();
if(pid < 0)
{
perror("fork error");
return -1;
}else if(pid == 0)
{
while(1)
{
//向消息队列中发送数据
Msg_ds msg = {.msgtype = 200};
printf("请输入消息内容:");
fgets(msg.data,sizeof(msg.data),stdin);
msg.data[strlen(msg.data)-1]='\0';
//将消息发送到消息队列中
if(msgsnd(msgid,&msg,SIZE,0) == -1)
{
perror("msgsnd error");
return -1;
}
if(strcmp(msg.data,"quit") == 0)
{
break;
}
}
}else{
while(1)
{
Msg_ds msg1;
if(msgrcv(msgid,&msg1,SIZE,100,0) == -1)
{
perror("msgrcv error");
return -1;
}
if(strcmp(msg1.data,"quit") == 0)
{
break;
}
printf("rcv:%s\n",msg1.data);
}
}
return 0;
}
效果图:
二、思维导图:有道云笔记