IPC对象,消息队列、共享内存、信号灯集

1.要求实现AB进程对话
a.A进程先发送一句话给B进程,B进程接收后打印

b.B进程再回复一句话A进程,A程接收后打印

c.重复1.2步骤,当收到quit后,要结束AB进程
提示:用一个消息队列,两种类型即可
a.当对方输入quit后,退出AB进程删除消息队列;

//*****************A进程****************************************//

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
struct msgbuf
{
    long mtype;
    char mtext[128];
};
int main(int argc, const char *argv[])
{
    // 计算key值;
    key_t key = ftok("../8day", 1);
    if (key < 0)
    {
        perror("ftok");
        return -1;
    }
    printf("key=%#x\n", key);
    // 通过key值找到对应的消息队列
    int msqid = msgget(key, IPC_CREAT | 0664);
    if (msqid < 0)
    {
        perror("msgget");
        return -1;
    }
    printf("msgget success msqid=%d\n", msqid);
    // system("ipcs -q");
    struct msgbuf snd;
    struct msgbuf rcv;
    while (1)
    {
        // 发送消息*********************************

        printf("请输入消息类型>>");
        scanf("%ld", &snd.mtype);
        getchar();
        if (0 == snd.mtype || snd.mtype < 0)
            break;
        printf("请输入消息内容>>");
        scanf("%s", snd.mtext);
        getchar();
        if (0 == strcmp(snd.mtext, "quit"))
        {
            msgctl(msqid, IPC_RMID, NULL);
            break;
        }

        // 发送消息到消息队列中

        if (msgsnd(msqid, &snd, sizeof(snd.mtext), 0))
        {
            perror("msgsnd");
            return -1;
        }
        printf("发送成功\n");

        // 接收消息***********************************

        if (msgrcv(msqid, &rcv, sizeof(rcv.mtext), 2, 0) < 0)
        {
            perror("msgrcv");
            return -1;
        }
        if (0 == strcmp(rcv.mtext, "quit"))
        {
            msgctl(msqid, IPC_RMID, NULL);
            break;
        }
        printf("type>>%ld mtext>>%s\n", rcv.mtype, rcv.mtext);
    }
    system("ipcs -q");
    return 0;
}

//******************B进程*******************************//

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
struct msgbuf
{
    long mtype;
    char mtext[128];
};
int main(int argc, const char *argv[])
{
    key_t key = ftok("../8day", 1);
    if (key < 0)
    {
        perror("ftok");
        return -1;
    }
    printf("%#x\n", key);
    // 通过key值找到对应的消息队列
    int msqid = msgget(key, IPC_CREAT | 0664);
    if (msqid < 0)
    {
        perror("msgget");
        return -1;
    }
    printf("msgget success msqid=%d\n", msqid);
    // system("ipcs -q");
    struct msgbuf rcv;
    struct msgbuf snd;
    while (1)
    {
        //接收消息*********************************************************


       //if(msgrcv(msqid,&rcv,sizeof(rcv.mtext),1,0)<0)
       //if(msgrcv(msqid,&rcv,sizeof(rcv.mtext),1,IPC_NOWAIT)<0)
       if(msgrcv(msqid,&snd,sizeof(snd.mtext),1,0)<0)
       {
        perror("msgrcv");
        return -1;
       }
       if (0 == strcmp(snd.mtext, "quit"))
       {
            msgctl(msqid,IPC_RMID,NULL);
            break;
       }
       printf("类型>>%ld 内容>>%s\n",snd.mtype,snd.mtext);

       //发送消息*********************************************************
   

        printf("请输入消息类型>>");
        scanf("%ld", &rcv.mtype);
        getchar();
        if (0 == rcv.mtype || rcv.mtype < 0)
            break;
        printf("请输入消息内容>>");
        scanf("%s", rcv.mtext);
        getchar();
        if (0 == strcmp(rcv.mtext, "quit"))
        {
            break;
            msgctl(msqid,IPC_RMID,NULL);//删除消息队列
        }

        // 发送消息到消息队列中

        if (msgsnd(msqid, &rcv, sizeof(rcv.mtext), 0))
        {
            perror("msgsnd");
            return -1;
        }
        printf("发送成功\n");

    }
    system("ipcs -q");
    return 0;
}

输出结果为:

 ///在第一个基础上利用多进程实现两端自由通信

2、—个进程对共享内存中的数据打印,另一个进程对共享内存中的数据倒置。

提示:共享内存中存储: flag+字符串

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <sys/wait.h>
#include <unistd.h>
#define SHMSIZE 8 // 共享内存大小

int main(int argc, const char *argv[])
{
    int flag = 0;
    key_t key = ftok("./", 1); // 获取key值
    if (key < 0)
    {
        perror("ftok");
        return -1;
    }
    printf("key=%#x\n", key);
    // 创建共享内存的shmid
    // int shmid=shmget(key,SHMSIZE,IPC_CREAT|0664);
    int shmid = shmget(key, SHMSIZE, IPC_CREAT | 0664);
    if (shmid < 0)
    {
        perror("shmget");
        return -1;
    }
    printf("shmid=%d\n", shmid);
    // 将共享内存映射到用户空间中使用 shmat
    void *addr = shmat(shmid, NULL, 0);
    if ((void *)-1 == addr)
    {
        perror("shmat");
        return -1;
    }
    // printf("addr=%p\n",addr);
    strcpy((char *)addr, "1234567");
    pid_t pid = fork(); // 创建子进程
    if (pid < 0)
    {
        perror("fork");
        return -1;
    }
    else if (0 == pid) // 子进程:逆序打印字符串
    {
        //if(1 == flag)
        //{
            sleep(1);
            printf("child will print reserved string:\n");
            for (int i = SHMSIZE - 2; i >= 0; i--)
            {
                putchar(*((char *)addr + i));
            }
            putchar('\n');
        //}
    }
    else // 父进程:顺序打印字符串
    {
       // if(0 == flag)
        //{
            printf("parent will print original string:\n");
            printf("%s\n", (char *)addr);
            flag = 1;
            if (-1 == waitpid(pid, NULL, 0))
            {
                perror("waitpid");
                return -1;
            }
            if (-1 == shmdt(addr))
            {
                perror("shmdt");
                return -1;
            }
            if (-1 == shmctl(shmid, IPC_RMID, NULL))
            {
                perror("shmctl");
                return -1;
            }
       // }
    }

    return 0;
}

输出结果为:

 

标题SpringBoot基层智能化人员调度系统研究AI更换标题第1章引言介绍SpringBoot基层智能化人员调度系统的研究背景、意义、现状以及论文的研究方法和创新点。1.1研究背景与意义分析当前基层人员调度的现状和问题,阐述智能化调度的必要性和意义。1.2国内外研究现状概述国内外在基层智能化人员调度系统方面的研究进展和应用情况。1.3论文方法及创新点介绍本文采用的研究方法和实现智能化人员调度系统的创新点。第2章相关理论阐述SpringBoot框架、智能化调度算法和人员调度理论。2.1SpringBoot框架概述介绍SpringBoot框架的特点、优势和应用场景。2.2智能化调度算法总结现有的智能化调度算法,并分析其优缺点。2.3人员调度理论基础阐述人员调度的基本概念、原则和方法。第3章系统需求分析对SpringBoot基层智能化人员调度系统进行需求分析,包括功能性需求和非功能性需求。3.1功能性需求明确系统需要实现的功能,如人员信息管理、任务分配、调度策略制定等。3.2非功能性需求分析系统的性能、安全性、可靠性等非功能性需求。3.3需求优先级划分根据实际需求,对各项需求进行优先级划分。第4章系统设计详细介绍SpringBoot基层智能化人员调度系统的设计方案,包括架构设计、数据库设计和界面设计。4.1架构设计给出系统的整体架构,包括前后端分离、微服务架构等设计理念。4.2数据库设计设计合理的数据库表结构,满足系统的数据存储和查询需求。4.3界面设计设计简洁、易用的用户界面,提升用户体验。第5章系统实现阐述SpringBoot基层智能化人员调度系统的具体实现过程,包括核心代码实现、功能模块实现等。5.1核心代码实现详细介绍系统核心功能的代码实现,如人员信息管理、任务分配算法等。5.2功能模块实现分别介绍各个功能模块的实现过程,如用户登录、人员信息管理、任务管理等。第6章系统
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值