进程间的通信

建立两个.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;
}
相关推荐
多看书少吃饭3 分钟前
从Vue到Nuxt.js
前端·javascript·vue.js
大学生资源网8 分钟前
java毕业设计之儿童福利院管理系统的设计与实现(源码+)
java·开发语言·spring boot·mysql·毕业设计·源码·课程设计
JasmineWr8 分钟前
JVM栈空间的使用和优化
java·开发语言
Hello.Reader13 分钟前
Flink SQL DELETE 语句批模式行级删除、连接器能力要求与实战避坑(含 Java 示例)
java·sql·flink
前端一小卒14 分钟前
从 v5 到 v6:这次 Ant Design 升级真的香
前端·javascript
爱笑的眼睛1116 分钟前
从 Seq2Seq 到 Transformer++:深度解构与自构建现代机器翻译核心组件
java·人工智能·python·ai
Spring AI学习23 分钟前
Spring AI深度解析(10/50):多模态应用开发实战
java·spring·ai
前端不太难1 小时前
《Vue 项目路由 + Layout 的最佳实践》
前端·javascript·vue.js
LYFlied1 小时前
【每日算法】 LeetCode 56. 合并区间
前端·算法·leetcode·面试·职场和发展
想学后端的前端工程师2 小时前
【Vue3组合式API实战指南:告别Options API的烦恼】
前端·javascript·vue.js