【无标题】

进程间通信 消息队列

编写一个C程序,先后fork两个子进程,分别是SERVER和CLIENT。

  1. SEVER端建立一个key为75的消息队列,等待其他进程发来的消息。当遇到类型为1的消息,则 作为结束信号,取消该队列,并退出SERVER。SERVER每接收到一个消息后显示“(server)
    received + 消息内容”。
  2. CLIENT端使用key 为75的消息队列,先后发送类型从10到1的消息,然后退出。最后的一个消 息,即是SERVER端需要的结束信号。CLIENT每发出一条消息后显示“(client) sent +消息内
    容”。
  3. 父进程在SERVER和CLIENT均退出后结束。

代码实现

#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/wait.h>
#include <sys/msg.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct _msg
{
        long mtype;
        char mtext[50];
}msg;
int main()
{
        int mid;
        pid_t pid1, pid2;
        while ((pid1 = fork()) == -1);//直到创建子进程成功为止
        if (!pid1)
        {
                while((mid=msgget(75,IPC_CREAT | 0666))==-1);//创建消息队列
                msg mq; 结构体变量
                //子1
                for (int i = 10; i > 0; i--)
                {
                        sprintf(mq.mtext, "%s:%d", "dataType is", i);
mq.mtype = i;
                        msgsnd(mid, &mq, sizeof(mq.mtext), 0); //发送消息
                        printf("(client) sent %s\n", mq.mtext);
                }
                sleep(2);
                exit(0);//子进程1退出
        }
        else
        {
                while ((pid2 = fork()) == -1);
                if (!pid2)
                {
                        int mid = msgget(75,IPC_CREAT | 0666);
                        msg mq;
                        //子进程2
                        for (int j = 10; j > 0; j--)
                        {
                                int mid=msgget(75,0666);
                                msgrcv(mid, &mq, sizeof(mq.mtext), j, 0);
                                printf("(server) received %s\n", mq.mtext);
                                if (mq.mtype == 1)
                                {
                                        exit(0);//遇到消息类型为1的就停止接收消息
                                }
                        }
}
                else//等待两个子进程都退出后 父进程退出
                {
                        wait(NULL);
                        exit(0);
                }
        }
        return 0;
}

运行结果若有误 欢迎指正

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值