进程间的通信

建立两个.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;
}
相关推荐
静小谢10 分钟前
前后台一起部署,vite配置笔记base\build
前端·javascript·笔记
用户479492835691533 分钟前
改了CSS刷新没反应-你可能不懂HTTP缓存
前端·javascript·面试
FLGB1 小时前
maven漏洞检测报告
java·maven
还好还好不是吗1 小时前
老项目改造 vue-cli 2.6 升级 rsbuild 提升开发效率300% upupup!!!
前端·性能优化
sumAll1 小时前
别再手动对齐矩形了!这个开源神器让 AI 帮你画架构图 (Next-AI-Draw-IO 体验)
前端·人工智能·next.js
OpenTiny社区1 小时前
2025OpenTiny星光ShowTime!年度贡献者征集启动!
前端·vue.js·低代码
农夫山泉2号1 小时前
【c++】——c++编译的so中函数有额外的字符
java·服务器·c++
wangan0941 小时前
不带圆圈的二叉树
java·前端·javascript
狗哥哥1 小时前
从零到一:打造企业级 Vue 3 高性能表格组件的设计哲学与实践
前端·vue.js·架构
疯狂平头哥1 小时前
微信小程序真机预览-数字不等宽如何解决
前端