2/23 work

1> 使用消息队列完成两个进程间相互

a:

#include<myhead.h>
#define MSGSIZE sizeof(struct msgbuf)-sizeof(long)
struct msgbuf
{long mtype;char mtext[1024];};
int main(int argc, const char *argv[])
{pid_t pid=fork();if(pid>0){key_t key = 0;if((key=ftok("/",'k'))==-1){perror("ftok error");return -1;}printf("ftok success key = %#x\n",key);int msqid = -1;if((msqid = msgget(key,IPC_CREAT|0664))==-1){perror("msgget error");return -1;}printf("msgget success msqid = %d\n",msqid);struct msgbuf sbuf;while(1){bzero(sbuf.mtext, sizeof(sbuf.mtext));printf("消息类型:");scanf("%ld",&sbuf.mtype);getchar();printf("请输入正文:");fgets(sbuf.mtext,sizeof(sbuf.mtext), stdin);sbuf.mtext[strlen(sbuf.mtext)-1]=0;msgsnd(msqid,&sbuf, MSGSIZE, 0);printf("发送成功\n");if(strcmp(sbuf.mtext, "quit")==0){break;}}}else if(pid==0){key_t key1 = 0;if((key1=ftok("/",'k'))==-1){perror("ftok error");return -1;}printf("ftok success key1 = %#x\n",key1);int msqid1 = -1;if((msqid1 = msgget(key1,IPC_CREAT|0664))==-1){perror("msgget error");return -1;}printf("msgget success msqid1 = %d\n",msqid1);struct msgbuf rbuf;while(1){bzero(rbuf.mtext, sizeof(rbuf.mtext));msgrcv(msqid1,&rbuf,MSGSIZE,2,0);printf("收到消息为:%s\n",rbuf.mtext);if(strcmp(rbuf.mtext, "quit")==0){break;}}if(msgctl(msqid1,IPC_RMID,NULL)!=0){perror("msgctl error");return -1;}}else{perror("fork error");return -1;}return 0;
}

b: 

#include<myhead.h>
#define MSGSIZE sizeof(struct msgbuf)-sizeof(long)
struct msgbuf
{long mtype;char mtext[1024];};
int main(int argc, const char *argv[])
{pid_t pid=fork();if(pid>0){key_t key = 0;if((key=ftok("/",'k'))==-1){perror("ftok error");return -1;}printf("ftok success key = %#x\n",key);int msqid = -1;if((msqid = msgget(key,IPC_CREAT|0664))==-1){perror("msgget error");return -1;}printf("msgget success msqid = %d\n",msqid);struct msgbuf sbuf;while(1){bzero(sbuf.mtext, sizeof(sbuf.mtext));printf("消息类型:");scanf("%ld",&sbuf.mtype);getchar();printf("请输入正文:");fgets(sbuf.mtext,sizeof(sbuf.mtext), stdin);sbuf.mtext[strlen(sbuf.mtext)-1]=0;msgsnd(msqid,&sbuf, MSGSIZE, 0);printf("发送成功\n");if(strcmp(sbuf.mtext, "quit")==0){break;}}}else if(pid==0){key_t key1 = 0;if((key1=ftok("/",'k'))==-1){perror("ftok error");return -1;}printf("ftok success key1 = %#x\n",key1);int msqid1 = -1;if((msqid1 = msgget(key1,IPC_CREAT|0664))==-1){perror("msgget error");return -1;}printf("msgget success msqid = %d\n",msqid1);struct msgbuf rbuf;while(1){bzero(rbuf.mtext, sizeof(rbuf.mtext));msgrcv(msqid1,&rbuf,MSGSIZE,1,0);printf("收到消息为:%s\n",rbuf.mtext);if(strcmp(rbuf.mtext, "quit")==0){break;}}if(msgctl(msqid1,IPC_RMID,NULL)!=0){perror("msgctl error");return -1;}}else{perror("fork error");return -1;}return 0;
}

 

2>思维导图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/702348.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微信小程序自制动态导航栏

写在前面 关于微信小程序导航栏的问题以及解决办法我已经在先前的文章中有提到&#xff0c;点击下面的链接即可跳转~ &#x1f90f;微信小程序自定义的导航栏&#x1f90f; 在这篇文章中我们需要做一个这样的导航栏&#xff01;先上效果图 &#x1f447;&#x1f447;&#x1f…

vue3个人网站电子宠物

预览 具体代码 Attack.gif Attacked.gif Static.gif Walk.gif <template><div class"pet-container" ref"petContainer"><p class"pet-msg">{{ pet.msg }}</p><img ref"petRef" click"debounce(attc…

一文带你彻底搞懂 Python 编程进阶之闭包

什么是闭包&#xff1a;在函数嵌套的情况下&#xff0c;内部的函数使用外部函数中的变量&#xff0c;并且外部函数返回了内部函数&#xff0c;我们将这个内部函数称之为闭包。 闭包是实现装饰器的基础&#xff0c;通过装饰器可以在不修改原函数代码的情况下增强其功能。 在Py…

【elasticsearch】搜索结果处理

搜索结果处理 排序 elasticsearch支持对搜索结果排序&#xff0c;默认是根据相关度算分&#xff08;_score&#xff09;来排序。可以排序字段类型有&#xff1a;keyword类型、数值类型、地理坐标类型、日期类型等。 GET /indexName/_search {"query":{"match_a…

C++多继承之菱形继承原理及解决方法

目录 1.单继承和多继承 2.菱形继承 3.虚继承解决菱形继承 3.1使用方法 3.2虚继承原理 4.继承和组合 1.单继承和多继承 一个子类只有一个父类称为单继承 一个子类有多个父类称为多继承 2.菱形继承 菱形继承是多继承的一种复杂的情况 这里会出现一个问题&#xff0c;Assi…

prometheus+grafana监控nginx的简单实现

1.编译安装NGINX 加入编译安装nginx-module-vts模块,目的是为了获取更多的监控数据(虚拟主机&#xff0c;upstream等) nginx下载 http://nginx.org/download/nginx-1.20.2.tar.gz nginx-module-vts下载 https://github.com/vozlt/nginx-module-vts/archive/refs/tags/v0.2…

谁是单身狗?——C语言刷题

创造不易&#xff0c;可以点点赞吗~ 如有错误&#xff0c;欢迎指出~ 单身狗1 题述 在一个整型数组中&#xff0c;只有一个数字出现一次&#xff0c;其他数组都是成对出现的&#xff0c;请找出那个只出现一次的数字。 例如&#xff1a; 数组中有&#xff1a;1 2 3 4 5 1 2 3 4&a…

【Docker】docker常用命令

需要云服务器等云产品来学习Linux可以移步/-->腾讯云<--/官网&#xff0c;轻量型云服务器低至112元/年&#xff0c;新用户首次下单享超低折扣。 目录 一、镜像仓库架构图 二、docker仓库命令 1、登录仓库docker login 2、拉取镜像docker pull 3、推送镜像docker pus…

电子器件系列64:稳压二极管ZM4728A

C143062_稳压二极管_ZM4728A-GS08_规格书_WJ481159 稳压管可以用于信号线路的旁路&#xff0c;用于过滤高频信号&#xff1f; 这种电路叫做限幅电路 从集成电路Al的①脚输出信号通过Rl加到集成电路A2的①脚。当集成电路Al的①脚输出信号幅度没有超过VD1稳压值时&#xff0c;这…

【Python】Windows本地映射远程Linux服务器上的端口(解决jupyter notebook无法启动问题)

创作日志&#xff1a; 学习深度学习不想在本地破电脑上再安装各种软件&#xff0c;我就用实验室的服务器配置环境&#xff0c;启动jupyter notebook时脑子又瓦特了&#xff0c;在自己Windows电脑上打开服务器提供的网址&#xff0c;那肯定打不开啊&#xff0c;以前在其它电脑上…

轮盘类零件

轮盘类零件 轮盘类零件也是组成机器的常见零件&#xff0c;如法兰盘、轴承端盖、各种泵盖、齿轮、蜗轮、链轮、带轮、飞轮、手轮、离合器中的摩擦盘等。轮类零件主要传递运动及动力&#xff0c;如齿轮、蜗轮、链轮、带轮、飞轮、手轮等;盘盖类零件主要起支承、轴向定位或密…

Vue.js+SpringBoot开发超市商品管理系统

目录 一、摘要1.1 简介1.2 项目录屏 二、研究内容2.1 数据中心模块2.2 超市区域模块2.3 超市货架模块2.4 商品类型模块2.5 商品档案模块 三、系统设计3.1 用例图3.2 时序图3.3 类图3.4 E-R图 四、系统实现4.1 登录4.2 注册4.3 主页4.4 超市区域管理4.5 超市货架管理4.6 商品类型…

JSTL标签

JSTL标签 一、什么是JSTL标签&#xff1a; 随着J2EE瘦客户机技术JavaServer Pages(JSP)在过去几年中的流行&#xff0c;开发人员已经创建了许多自定义的JSP标记库。虽然很多标记库是为实现不同目标的而编写的&#xff0c;但它们往往也对迭代、条件及其它通用操作都提供了类似…

Java常用设计模式

文章目录 代理模式代理模式的作用静态代理动态代理动态代理的两种方式 代理模式 代理模式&#xff1a;当我们要去访问一个目标类的时候&#xff0c;不是直接去访问这个目标类&#xff0c;而是去访问这个目标类的代理类&#xff0c;由这个代理类去调用目标类。也就是我们间接的…

【数据结构】图——最短路径

最短路径问题&#xff1a;从在带权有向图G中的某一顶点出发&#xff0c;找出一条通往另一顶点的最短路径&#xff0c;最短也就是沿路径各边的权值总和达到最小。 最短路径分为图中单源路径和多源路径。 本文会介绍Dijkstra和Bellman-Ford解决单源路径的问题 Floyd-Warshall解…

来看大厂如何设计运营后台系统的?

0 背景 重运营的应用。对于App里的顶导航、我的页面、弹窗等&#xff0c;需要根据模式、版本、平台、语言、渠道等不同的维度进行运营管理。随着业务快速发展&#xff0c;版本快速迭代&#xff0c;如何&#xff1a; 保持运营资源能够被高效、稳定和灵活地配置高效稳定的为新的…

【洛谷千题详解】P1031 均分纸牌

目录 题目描述 思路点拨 AC代码 题目描述 题目网址&#xff1a;[NOIP2002 提高组] 均分纸牌 - 洛谷 有 N 堆纸牌&#xff0c;编号分别为 1,2,……,N。每堆上有若干张&#xff0c;但纸牌总数必为 N 的倍数。可以在任一堆上取若干张纸牌&#xff0c;然后移动。 移牌规则为&a…

YOLO如何训练自己的模型

目录 步骤 一、打标签 二、数据集 三、跑train代码出模型 四、跑detect代码出结果 五、详细操作 步骤 一、打标签 &#xff08;1&#xff09;在终端 pip install labelimg &#xff08;2&#xff09;在终端输入labelimg打开 如何打标签&#xff1a; 推荐文章&#xf…

代码随想录算法训练营day27|39. 组合总和、40.组合总和II

39. 组合总和 如下树形结构如下&#xff1a; 选取第二个数字5之后&#xff0c;剩下的数字要从5、3中取数了&#xff0c;不能再取2了&#xff0c;负责组合就重复了&#xff0c;注意这一点&#xff0c;自己做的时候没想明白这一点 如果是一个集合来求组合的话&#xff0c;就需…

找游戏 - 华为OD统一考试(C卷)

OD统一考试&#xff08;C卷&#xff09; 分值&#xff1a; 200分 题解&#xff1a; Java / Python / C 题目描述 小扇和小船今天又玩起来了数字游戏&#xff0c; 小船给小扇一个正整数 n&#xff08;1 ≤ n ≤ 1e9&#xff09;&#xff0c;小扇需要找到一个比 n 大的数字 m&a…