进程间的通信

建立两个.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;
}
相关推荐
竹林8182 分钟前
在Web3前端用Node.js子进程批量校验钱包,我踩了这些性能与安全的坑
javascript·node.js
左左右右左右摇晃4 分钟前
Java并发——synchronized锁
java·开发语言
农夫山泉不太甜8 分钟前
Tauri v2 实战代码示例
前端
yuhaiqiang25 分钟前
被 AI 忽悠后,开始怀念搜索引擎了?
前端·后端·面试
红色石头本尊41 分钟前
1-umi-前端工程化搭建
前端
真夜1 小时前
关于对echart盒子设置百分比读取的宽高没有撑开盒子解决方案
前端
sxlishaobin1 小时前
Java I/O 模型详解:BIO、NIO、AIO
java·开发语言·nio
彭于晏Yan1 小时前
Spring AI(二):入门使用
java·spring boot·spring·ai
楠木6851 小时前
RAG 资料库 Demo 完整开发流程
前端·ai编程
有一个好名字1 小时前
vibe codeing 开发流程
java