进程间的通信

建立两个.c 建立子父进程,父进程发送消息到队列,子进程读取队列,另一个同样。

cs 复制代码
#include <myhead.h>
struct msga
{
    long mtype;
    char mtext[1024];
};
#define len sizeof(struct msga)-sizeof(long)
int main(int argc, const char *argv[])
{
    pid_t pid;
    pid=fork();
    if(pid>0)
    {
        key_t key=ftok("./",'L');
        if(key==-1)
        {
            perror("ftok");
            return -1;
        }
        int msgID=msgget(key,IPC_CREAT|0664);
        if(msgID==-1)
        {
            perror("msgget");
            return -1;
        }
        struct msga send;
        while(1)
        {
            printf("请输入消息类型:");
            scanf("%ld",&send.mtype);
            getchar();
            printf("请输入消息内容:");
            fgets(send.mtext,sizeof(send.mtext),stdin);
            send.mtext[strlen(send.mtext)-1]='\0';
            msgsnd(msgID,&send,len,0);
            if(strcmp(send.mtext,"quit")==0)
            {
                break;
            }
        }
        if(msgctl(msgID,IPC_RMID,NULL)==-1)
        {
            perror("msgctl");
            return -1;
        }
    }
    else if(pid==0)
    {
        key_t key=ftok("./",'Y');
        if(key==-1)
        {
            perror("ftok");
            return -1;
        }
        int msgID=msgget(key,IPC_CREAT|0664);
        if(msgID==-1)
        {
            perror("msgget");
            return -1;
        }
        struct msga rev;
        while(1)
        {
            msgrcv(msgID,&rev,len,0,0);
            printf("%s\n",rev.mtext);
            if(strcmp(rev.mtext,"quit")==0)
            {
                break;
            }
        }
        if(msgctl(msgID,IPC_RMID,NULL)==-1)
        {
            perror("msgctl");
            return -1;
        }
    }
    else
    {
        perror("fork");
        return -1;
    }
    return 0;
}
cs 复制代码
#include <myhead.h>
struct msga
{
    long mtype;
    char mtext[1024];
};
#define len sizeof(struct msga)-sizeof(long)
int main(int argc, const char *argv[])
{
    pid_t pid;
    pid=fork();
    if(pid>0)
    {
        key_t key=ftok("./",'Y');
        if(key==-1)
        {
            perror("ftok");
            return -1;
        }
        int msgID=msgget(key,IPC_CREAT|0664);
        if(msgID==-1)
        {
            perror("msgget");
            return -1;
        }
        struct msga send;
        while(1)
        {
            printf("请输入消息类型:");
            scanf("%ld",&send.mtype);
            getchar();
            printf("请输入消息内容:");
            fgets(send.mtext,sizeof(send.mtext),stdin);
            send.mtext[strlen(send.mtext)-1]='\0';
            msgsnd(msgID,&send,len,0);
            if(strcmp(send.mtext,"quit")==0)
            {
                break;
            }
        }
        if(msgctl(msgID,IPC_RMID,NULL)==-1)
        {
            perror("msgctl");
            return -1;
        }
    }
    else if(pid==0)
    {
        key_t key=ftok("./",'L');
        if(key==-1)
        {
            perror("ftok");
            return -1;
        }
        int msgID=msgget(key,IPC_CREAT|0664);
        if(msgID==-1)
        {
            perror("msgget");
            return -1;
        }
        struct msga rev;
        while(1)
        {
            msgrcv(msgID,&rev,len,0,0);
            printf("%s\n",rev.mtext);
            if(strcmp(rev.mtext,"quit")==0)
            {
                break;
            }
        }
        if(msgctl(msgID,IPC_RMID,NULL)==-1)
        {
            perror("msgctl");
            return -1;
        }
    }
    else
    {
        perror("fork");
        return -1;
    }
    return 0;
}
相关推荐
HYI6 分钟前
「三年了,今晚突然开窍!」 一个拖拽排序的顿悟时刻
javascript·vue.js
程序猿阿越7 分钟前
Kafka源码(三)发送消息-客户端
java·后端·源码阅读
AliciaIr10 分钟前
深入理解HTTP:从协议基础到版本演进(上)
前端·http
pepedd86412 分钟前
数组字符串方法有哪些-带你重温js基础
前端·javascript·trae
whitepure13 分钟前
万字详解Java中的运算
java
pepedd86413 分钟前
深入理解js作用域-你真的懂js吗
前端·javascript·trae
AAA修煤气灶刘哥14 分钟前
搞定 Redis 不难:从安装到实战的保姆级教程
java·redis·后端
阿迪州15 分钟前
[函数式编程] 为什么要柯里化?
前端
MrSYJ17 分钟前
全局和局部AuthenticationManager
java·后端·程序员