当前位置: 首页 > news >正文

C语言第十二弹--扫雷

ce606f06783242e5a2c1c1e273b0c273.jpeg

  ✨个人主页: 熬夜学编程的小林

💗系列专栏: 【C语言详解】 【数据结构详解】

扫雷

1、扫雷游戏分析和设计

1.1、扫雷游戏的功能说明

1.2 游戏的分析和设计

1.2.1、数据结构的分析

1.2.2、文件结构设计

2、扫雷游戏的结构分析

2.1、用户选择

2.2、初始化棋盘

2.3、设置雷

2.4、排雷

3、扫雷游戏分文件的代码实现

3.1、test.c

3.2、game.c

3.3、game.h

4、扫雷游戏的扩展

总结


 

1、扫雷游戏分析和设计


1.1、扫雷游戏的功能说明

• 使用控制台实现经典的扫雷游戏
• 游戏可以通过菜单实现继续玩或者退出游戏
• 扫雷的棋盘是9*9的格子
• 默认随机布置10个雷
• 可以排查雷
◦ 如果位置不是雷,就显示周围有几个雷
◦ 如果位置是雷,就炸死游戏结束
◦ 把除10个雷之外的所有非雷都找出来,排雷成功,游戏结束


游戏的界面:

88ed8a3922264102b536571eccd01014.png


1.2 游戏的分析和设计


1.2.1、数据结构的分析


扫雷的过程中,布置的雷和排查出的雷的信息都需要存储,所以我们需要⼀定的数据结构来存储这些信息。
因为我们需要在9*9的棋盘上布置雷的信息和排查雷,我们首先想到的就是创建⼀个9*9的数组来存放信息。

那如果这个位置布置雷,我们就存放1,没有布置雷就存放0.
假设我们排查(2,5)这个坐标时,我们访问周围的⼀圈8个位置,统计周围雷的个数是1
假设我们排查(8,6)这个坐标时,我们访问周围的⼀圈8个位置,统计周围雷的个数时,最下面的三
个坐标就会越界,为了防止越界,我们在设计的时候,给数组扩大⼀圈,雷还是布置在中间的9*9的坐标上,周围⼀圈不去布置雷就行,这样就解决了越界的问题。所以我们将存放数据的数组创建成11*11是比较合适。


再继续分析,我们在棋盘上布置了雷,棋盘上雷的信息(1)和非雷的信息(0),假设我们排查了某个位置后,这个坐标处不是雷,这个坐标的周围有1个雷,那我们需要将排查出的雷的数量信息记录存储,并打印出来,作为排雷的重要参考信息的。那这个雷的个数信息存放在哪里呢?如果存放在布置雷的数组中,这样雷的信息和雷的个数信息就可能或产生混淆和打印上的困难。
这里我们肯定有办法解决,比如:雷和非雷的信息不要使用数字,使用某些字符就行,这样就避免冲突了,但是这样做棋盘上有雷和非雷的信息,还有排查出的雷的个数信息,就比较混杂,不够方便。


这里我们采用另外⼀种方案,我们专门给⼀个棋盘(对应⼀个数组mine)存放布置好的雷的信息,再给另外⼀个棋盘(对应另外⼀个数组show)存放排查出的雷的信息。这样就互不干扰了,把雷布置到mine数组,在mine数组中排查雷,排查出的数据存放在show数组,并且打印show数组的信息给后期排查参考。


同时为了保持神秘,show数组开始时初始化为字符 '*',为了保持两个数组的类型⼀致,可以使用同⼀套函数处理,mine数组最开始也初始化为字符'0',布置雷改成'1'。如下如:
对应的数组应该是:
char mine[11][11] = {0};//用来存放布置好的雷的信息
char show[11][11] = {0};//用来存放排查出的雷的个数信息


1.2.2、文件结构设计


之前学习了多文件的形式对函数的声明和定义,这里我们实践⼀下,我们设计三个⽂件:

test.c //文 件中写游戏的测试逻辑
game.c //文 件中写游戏中函数的实现等
game.h //文 件中写游戏需 要的数据类型和函数声明等

建议:写一些代码就测试一些代码。


2、扫雷游戏的结构分析

2.1、用户选择

首先用户选择需要的功能,输入1则进入游戏,输入0则退出游戏,输入其他值则重新输入。

从这可以知道此处为一个循环,而且一定会进入一次,符号do while的特性,因此使用do while循环,但是此处需要打印一个选项的界面,因此可以使用创建一个菜单。

0e09178842444c6a84427b2e3cea2938.png

#include<stdio.h>
//菜单
void menu()
{printf("******************************\n");printf("*********   1.play   *********\n");printf("*********   0.exit   *********\n");printf("******************************\n");
}
int main()
{int input = 0;do{menu();printf("请选择:>\n");scanf("%d", &input);switch (input){case 1://游戏实现break;case 0:printf("游戏结束\n");break;default:printf("选择错误,请重新输入\n");break;}} while (input);//为假则退出循环,即输入0退出循环,游戏结束return 0;
}

2.2、初始化棋盘

根据前面的分析,创建一个能够对两个棋盘初始化的函数。参数有该数组,数组行号,列号,还有初始化的值(这样才能保证一个函数能够初始化两个棋盘),一个初始化为'0',一个初始化为'*',均为字符。为了测试我们需要将棋盘打印出来,此处需要创建一个打印棋盘的函数。参数有数组,行号,列号。

//初始化棋盘
void BoardInit(char board[ROWS][COLS], int rows, int cols, char set)
{int i = 0;int j = 0;for (i = 0; i < rows; i++){for (j = 0; j < cols; j++){board[i][j] = set;//棋盘初始为set字符}}
}
//打印棋盘
void BoardPrint(char board[ROWS][COLS], int row, int col)
{int i = 0;int j = 0;for (i = 1; i <= row; i++){for (j = 1; j <= col; j++){printf("%c ", board[i][j]);}printf("\n");}
}
int main()
{char mine[ROWS][COLS];//雷棋盘char show[ROWS][COLS];//展示棋盘//初始化雷棋盘BoardInit(mine, ROWS, COLS, '0');//初始化展示棋盘BoardInit(show, ROWS, COLS, '*');//打印雷棋盘BoardPrint(mine, ROW, COL);//打印展示棋盘BoardPrint(show, ROW, COL);return 0;
}

e80bf1e9d219464094fd06b4b61af1b5.png

 

优化之后

#include<stdio.h>
#define ROW 9 //原棋盘大小
#define COL 9#define ROWS ROW+2 //将原棋盘周围加一圈,即行列+2
#define COLS COL+2
void BoardInit(char board[ROWS][COLS], int rows, int cols, char set)
{int i = 0;int j = 0;for (i = 0; i < rows; i++){for (j = 0; j < cols; j++){board[i][j] = set;//棋盘初始为set字符}}
}
//打印棋盘
void BoardPrint(char board[ROWS][COLS], int row, int col)
{int i = 0;int j = 0;printf("------------扫雷游戏-------------\n");for (i = 0; i <= row; i++){printf("%d ", i);}printf("\n");for (i = 1; i <= row; i++){printf("%d ", i);for (j = 1; j <= col; j++){printf("%c ", board[i][j]);}printf("\n");}printf("------------扫雷游戏-------------\n");
}
int main()
{char mine[ROWS][COLS];//雷棋盘char show[ROWS][COLS];//展示棋盘//初始化雷棋盘BoardInit(mine, ROWS, COLS, '0');//初始化展示棋盘BoardInit(show, ROWS, COLS, '*');//打印雷棋盘BoardPrint(mine, ROW, COL);//打印展示棋盘BoardPrint(show, ROW, COL);return 0;
}

2221914255174ce1ae042ba587a22074.png

 

2.3、设置雷

按照前面要求,我们需要随机设置10个雷,那就需要用到随机数,C语言中有一个函数可以生成随机数,rand(),但是这个随机数不是真正的随机数(每次程序运行的数是一样的),因此需要用到一个时间函数才能做到真正的是随机数。即srand((unsigned int)time(NULL));随机数函数的头文件为#include<stdlib.h>,时间函数的头文件为#include<time.h>。

//设置雷
void MineSet(char board[ROWS][COLS], int row, int col)
{int count = MINE_COUNT;//#define定义为10个雷while (count){int x = rand() % row + 1;//生成随机数 rand()%row 区间为0-8 x区间为1-9int y = rand() % col + 1;//判断是否重复 没有重复则添加雷 即等于'0'则放入雷 '1'if (board[x][y] == '0'){board[x][y] = '1';count--;//随机数创建成功则count--}}
}
int main()
{srand((unsigned int)time(NULL));char mine[ROWS][COLS];//雷棋盘char show[ROWS][COLS];//展示棋盘//初始化雷棋盘BoardInit(mine, ROWS, COLS, '0');//初始化展示棋盘BoardInit(show, ROWS, COLS, '*');//设置雷MineSet(mine, ROW, COL);//打印雷棋盘BoardPrint(mine, ROW, COL);return 0;
}

打印和初始化棋盘的函数在前面有,此处就没有放上去了。

fcb0d58571b145899c490f3bf0967636.png

此处是在测试所以才需要打印存放雷的棋盘,真实游戏场景是不需要打印的。

 

2.4、排雷

排雷有三种情况:

1、如果是雷则结束
2、如果胜利则结束
3、不是雷且没有胜利则继续

根据扫雷游戏的界面,我们如果没有找到雷则需要继续排雷,因此可知此处需要使用循环实现。

排雷需要先输入坐标,然后判断是什么情况,如果坐标非法则重新输入,符合棋盘范围则判断为上述三种情况的哪种,如果不是雷且没有胜利则在展示棋盘中输出周围雷的个数再继续输入坐标继续排雷;如果是雷,输出游戏结束和打印存放雷的棋盘并退出循环;如果坐标重复了做一个提示并重新输入坐标;如果胜利则结束。

如何计算不是雷的坐标周围有几个雷呢?

此处可以创建一个计算几个雷的函数返回int类型,因为此处用的是字符数组,所以将该坐标周围的8个位置的值加起来,就是用字符表示个数,但是我们需要返回整数,所以需要减去8*'0',这样得到的结果就是整数的个数。

如何在展示棋盘打印该位置周围雷的个数呢?

在初始化棋盘时,我们的类型为字符类型,因此打印时也需要为字符类型,在上面我们通过函数计算了雷的个数,要将整型数字改成字符数字,只需加字符'0'即可。

如何判断胜利呢?

首先我们知道棋盘总共有行*列个,雷的个数在此处为10个,如果雷的个数加判断不是雷的个数之和等于棋盘个数,说明胜利。因此我们可以在不是雷且没有胜利的情况下创建一个变量,计算不是雷的个数,只要进入此条件则+1。

//计算雷个数
int COUNT_MINE_OF(char mine[ROWS][COLS], int x, int y)
{return mine[x - 1][y] +mine[x - 1][y + 1] +mine[x][y + 1] +mine[x + 1][y + 1] +mine[x + 1][y] +mine[x + 1][y - 1] +mine[x][y - 1] +mine[x - 1][y - 1] - 8 * '0';
}//排雷
void MineFind(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{//判断结束情况//1.如果是雷则结束//2.如果胜利则结束//3.不是雷且没有胜利则继续int x = 0;int y = 0;int win = 0;//判断不是雷的次数//1.先输入一个选择//如果符合条件则判断雷 不符合则循环while (win<row*col-MINE_COUNT)//如果棋盘-雷小于则进行判断游戏是否结束{printf("请输入你的坐标\n");scanf("%d %d", &x, &y);if (x >= 1 && x <= row && y >= 1 && y <= col){//被排查情况if (show[x][y] != '*'){printf("该坐标被排查过,请重重新输入坐标\n");}//区间正确 开始判断 开始找是否是雷 //如果是雷 则游戏结束else if (mine[x][y] == '1'){printf("游戏结束\n");BoardPrint(mine, ROW, COL);break;}//不是雷 判断周围有几个雷else{win++;//不是雷的个数+1int ret = COUNT_MINE_OF(mine, x, y);//计算该坐标周围雷的个数show[x][y] = ret + '0';//将字符数字赋值给展示棋盘BoardPrint(show, ROW, COL);//打印展示棋盘}}else{//棋盘区间不正确,则重新输入printf("输入错误,请重新输入\n");}}//雷的个数+不是雷的个数==棋盘个数 则胜利if (win == row * col - MINE_COUNT){printf("恭喜你胜利了\n");BoardPrint(mine, ROW, COL);}
}

如何测试赢的情况呢?

此处雷的个数为10个,不是雷的个数为71个,是不是要输入71次才能测试赢呢?此处博主的办法是直接把雷的个数改为80个,那么只有1个不是雷,我们将存储雷的棋盘打印出来,输入不是雷的下标,如果输出胜利则程序没有问题。

 f5cb7dec892a43f59a9b0ff97d4079b2.png

注:该游戏的棋盘大小和雷的个数都是通过#define定义,#define可以定义常数,此处这么定义的意义是如果需要改变棋盘大小或者雷个个数,只需要该#define的那一处就行,提高代码可读性和便捷性。

c33d118731e845cf8d044ecb0b60f300.png

3、扫雷游戏分文件的代码实现

test.c //文 件中写游戏的测试逻辑
game.c //文 件中写游戏中函数的实现等
game.h //文 件中写游戏需 要的数据类型和函数声明等

3.1、test.c

test.c代码

#define _CRT_SECURE_NO_WARNINGS
#include "game.h"
void menu()
{printf("******************************\n");printf("*********   1.play   *********\n");printf("*********   0.exit   *********\n");printf("******************************\n");
}
void game()
{//定义两个棋盘 一个表示雷状态 一个表示结果 9*9//最后需要判断周围8个元素的状态 但是可能会有越界情况//所以创建比原本大2的数组 遍历从1-大小char mine[ROWS][COLS];//雷棋盘char show[ROWS][COLS];//展示棋盘//初始化棋盘BoardInit(mine, ROWS, COLS,'0');BoardInit(show, ROWS, COLS,'*');//打印展示棋盘BoardPrint(show, ROW, COL);//设置雷MineSet(mine, ROW, COL);//排雷MineFind(mine, show, ROW, COL);
}
int main()
{srand((unsigned int)time(NULL));int input = 0;do{menu();printf("请选择:>\n");scanf("%d", &input);switch (input){case 1:game();break;case 0:printf("游戏结束\n");break;default:printf("选择错误,请重新输入\n");break;}} while (input);return 0;
}

3.2、game.c

game.c代码

#define _CRT_SECURE_NO_WARNINGS
#pragma once
#include "game.h"
//初始化棋盘
void BoardInit(char board[ROWS][COLS], int rows, int cols,char set)
{int i = 0;int j = 0;for (i = 0; i < rows; i++){for (j = 0; j < cols; j++){board[i][j] = set;}}
}
//打印棋盘
void BoardPrint(char board[ROWS][COLS], int row, int col)
{int i = 0;int j = 0;printf("------------扫雷游戏-------------\n");for (i = 0; i <= row; i++){printf("%d ", i);}printf("\n");for (i = 1; i <= row; i++){printf("%d ", i);for (j = 1; j <= col; j++){printf("%c ", board[i][j]);}printf("\n");}printf("------------扫雷游戏-------------\n");
}//设置雷
void MineSet(char board[ROWS][COLS], int row, int col)
{int count = MINE_COUNT;while (count){int x = rand() % row + 1;int y = rand() % col + 1;//判断是否重复 被等于'0'则放入雷 '1'if (board[x][y] == '0'){board[x][y] = '1';count--;}}
}
//计算雷个数
int COUNT_MINE_OF(char mine[ROWS][COLS], int x, int y)
{return mine[x - 1][y] +mine[x - 1][y + 1] +mine[x][y + 1] +mine[x + 1][y + 1] +mine[x + 1][y] +mine[x + 1][y - 1] +mine[x][y - 1] +mine[x - 1][y - 1] - 8 * '0';
}//排雷
void MineFind(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{//判断结束情况//1.如果是雷则结束//2.如果胜利则结束//3.不是雷且没有胜利则继续int x = 0;int y = 0;int win = 0;//判断不是雷的次数//1.先输入一个选择//如果符合条件则判断雷 不符合则循环while (win<row*col-MINE_COUNT)//如果棋盘-雷小于则进行判断游戏是否结束{printf("请输入你的坐标\n");scanf("%d %d", &x, &y);if (x >= 1 && x <= row && y >= 1 && y <= col){//被排查情况if (show[x][y] != '*'){printf("该坐标被排查过,请重重新输入坐标\n");}//区间正确 开始判断 开始找是否是雷 //如果是雷 则游戏结束else if (mine[x][y] == '1'){printf("游戏结束\n");BoardPrint(mine, ROW, COL);break;}//不是雷 判断周围有几个雷else{win++;//不是雷的个数+1int ret = COUNT_MINE_OF(mine, x, y);//计算该坐标周围雷的个数show[x][y] = ret + '0';//将字符数字赋值给展示棋盘BoardPrint(show, ROW, COL);//打印展示棋盘}}else{//棋盘区间不正确,则重新输入printf("输入错误,请重新输入\n");}}//雷的个数+不是雷的个数==棋盘个数 则胜利if (win == row * col - MINE_COUNT){printf("恭喜你胜利了\n");BoardPrint(mine, ROW, COL);}
}

3.3、game.h

game.h代码

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define ROW 9 //原棋盘大小
#define COL 9#define ROWS ROW+2 //将原棋盘周围加一圈,即行列+2
#define COLS COL+2#define MINE_COUNT 10//初始化棋盘
void BoardInit(char board[ROWS][COLS],int rows,int cols,char set);
//打印棋盘
void BoardPrint(char board[ROWS][COLS], int row, int col);
//设置雷
void MineSet(char board[ROWS][COLS], int row, int col);
//排雷
void MineFind(char mine[ROWS][COLS],char show[ROWS][COLS], int row, int col);
//计算雷个数
int COUNT_MINE_OF(char mine[ROWS][COLS],int x,int y);

4、扫雷游戏的扩展


• 是否可以选择游戏难度
◦ 简单 9*9 棋盘,10个雷
◦ 中等 16*16棋盘,40个雷
◦ 困难 30*16棋盘,99个雷
• 如果排查位置不是雷,周围也没有雷,可以展开周围的⼀⽚
• 是否可以标记雷
• 是否可以加上排雷的时间显示
在线扫雷游戏:http://www.minesweeper.cn/

总结

本篇博客就结束啦,谢谢大家的观看,如果公主少年们有好的建议可以留言喔,谢谢大家啦!

 

相关文章:

C语言第十二弹--扫雷

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】 扫雷 1、扫雷游戏分析和设计 1.1、扫雷游戏的功能说明 1.2 游戏的分析和设计 1.2.1、数据结构的分析 1.2.2、文件结构设计 2、扫雷游戏的结构分析 2.1、用…...

网路服务器——线程池技术

文章目录 一、线程池技术二、使用原理三、优点总结 一、线程池技术 预创建原则&#xff0c;线程池内部准备线程备用&#xff0c; 不宜过多。线程应该重用性&#xff0c;可以一对多处理任务或服务不同的客户端。处理单元(线程)数量并不固定&#xff0c;动态扩容与缩减(任务量)。…...

探索设计模式的魅力:深入了解适配器模式-优雅地解决接口不匹配问题

设计模式专栏&#xff1a;http://t.csdnimg.cn/nolNS 目录 一、引言 1. 概述 2. 为什么需要适配器模式 3. 本文的目的和结构 二、简价 1. 适配器模式的定义和特点 定义 特点 2. 适配器模式的作用和适用场景 作用 适用场景 3. 适配器模式与其他设计模式的比较 三、适配…...

matlab窗函数-hann窗和hamming窗函数

窗函数的作用 在时域上&#xff0c;窗函数可以看作是对原始信号进行截断或调制的加权函数。这些窗函数通常在时域上是有限的宽度&#xff0c;并且具有对称性&#xff0c;如矩形窗、汉宁窗、汉明窗和布莱克曼窗等。例如&#xff0c;汉明窗是一种对称窗函数&#xff0c;它可以用…...

Java项目实战--瑞吉外卖DAY03

目录 P22新增员工_编写全局异常处理器 P23新增员工_完善全局异常处理器并测试 p24新增员工_小结 P27员工分页查询_代码开发1 P28员工分页查询_代码开发2 P22新增员工_编写全局异常处理器 在COMMON新增全局异常捕获的类&#xff0c;其实就是代理我们这些controlle。通过aop把…...

docker 里使用vcs 2018 verdi等eda 图形界面

书接上文。之前借用别人的docker&#xff0c;使用EDA工具&#xff0c;苦于没有图形界面。如果只是编码&#xff0c;编译可能问题不大&#xff0c;但是如果要看波形之类的&#xff0c;就没法实现了。 docker 使用 vcs/2018 Verdi等 eda 软件-CSDN博客https://blog.csdn.net/guy…...

OpenHarmony—不支持解构赋值

规则&#xff1a;arkts-no-destruct-assignment 级别&#xff1a;错误 ArkTS不支持解构赋值。可使用其他替代方法&#xff0c;例如&#xff0c;使用临时变量。 TypeScript let [one, two] [1, 2]; // 此处需要分号 [one, two] [two, one];let head, tail [head, ...tail]…...

让AI帮你说话--GPT-SoVITS教程

有时候我们在录制视频的时候&#xff0c;由于周边环境嘈杂或者录音设备问题需要后期配音&#xff0c;这样就比较麻烦。一个比较直观的想法就是能不能将写好的视频脚本直接转换成我们的声音&#xff0c;让AI帮我们完成配音呢&#xff1f;在语音合成领域已经有很多这类工作了&…...

线性回归需要满足的几个假设

线性回归模型是基于一些假设构建的&#xff0c;这些假设有助于确保模型的有效性和可解释性。以下是线性回归需要满足的几个主要假设&#xff1a; 线性关系假设&#xff08;Linearity&#xff09;: 线性回归假设因变量&#xff08;目标变量&#xff09;与自变量&#xff08;特征…...

go语言(十八)---- goroutine

一、goroutine package mainimport ("fmt""time" )func main() {//用go创建承载一个形参为空&#xff0c;返回值为空的一个函数go func() {defer fmt.Println("A.defer")func() {defer fmt.Println("B.defer")//退出当前goroutinefmt…...

城市开发区视频系统建设方案:打造视频基座、加强图像数据治理

一、背景需求 随着城市建设的步伐日益加快&#xff0c;开发区已经成为了我国工业化、城镇化和对外开放的重要载体。自贸区、开发区和产业园的管理工作自然也变得至关重要。在城市经开区的展览展示馆、进出口商品展示交易中心等地&#xff0c;数千路监控摄像头遍布各角落&#…...

宏景eHRSmsAcceptGSTXServle存在XXE漏洞

指纹特征 app"HJSOFT-HCM"漏洞复现 POST /servlet/sms/SmsAcceptGSTXServlet HTTP/1.1 Host: User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36 Content-Length: 137 Content…...

LLVM实战之模块化设计

目录 1. llvm基础理念 2. 准备工作 3. 详细步骤 3.1 指令合并优化 3.2 无用参数消除优化 4. Pass管理器(Pass Manager)...

可以运行在浏览器的Windows 2000

Windows 2000 可以在浏览器里跑了&#xff0c;缺点就是速度慢。 JSLinux JSLinux 在浏览器中运行 Linux 或其他操作系统&#xff01; 可以使用以下仿真系统&#xff1a; 中央处理器操作系统用户 界面VF同步 访问启动 链接TEMU 配置评论x86阿尔派Linux 3.12.0安慰是的点击这…...

CUDA笔记

CUDA笔记 nvidia-smi 命令使用 nvidiasmi -q&#xff1a;查询GPU详细信息&#xff1b; nvidia-smi -q -l 0&#xff1a;查询特定GPU详细信息&#xff1b; nvidia-smi -q -l 0 -d MEMORY&#xff1a;显示GPU特定信息&#xff1b; nvidia-smi -h&#xff1a;英伟达的帮助命令。…...

Open CASCADE学习| ​提取曲面的PCurve

PCurve这个概念&#xff0c;字面上来理解就是参数曲线&#xff08;Parametric Curve&#xff09;。参数空间曲线是在参数曲面的双参数空间中的二维样条曲线。 二维曲线定义的目的只有一个&#xff1a;pCurve&#xff0c;参数曲线。OCC采用参数法构建几何结构&#xff0c;所有的…...

GMS测试BTSfail-CVE-2022-20451

描述&#xff1a; 项目需要过GMS兼容性测试&#xff0c;BTS这块我们环境没有&#xff0c;送检之后出现了一个BTS的Alert&#xff0c;这个是必须要解决的。下面的warning可以不考虑。 这个是patch问题&#xff0c;根据代理提供的pdf文件找到一个id:为A-235098883的补丁&#xf…...

Vue学习笔记12--Vue3之setup/ref函数/reactive函数/Vue3响应式原理/reactive对比ref

一、拉开序幕的setup 理解&#xff1a;Vue3中一个新的配置项&#xff0c;值为一个函数。setup是所有Composition API(组合API&#xff09;表演的舞台。组件中所用到的&#xff1a;数据、方法等&#xff0c;均要配置在setup中。setup函数的两种返回值&#xff1a; 若返回一个对…...

座位预约|座位预约小程序|基于微信小程序的图书馆自习室座位预约管理系统设计与实现(源码+数据库+文档)

座位预约小程序目录 目录 基于微信小程序的图书馆自习室座位预约管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、管理员服务端功能模块 2、学生微信端功能模块 四、数据库设计 1、实体ER图 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 …...

03 Redis之命令(基本命令+Key命令+String型Value命令与应用场景)

Redis 根据命令所操作对象的不同&#xff0c;可以分为三大类&#xff1a;对 Redis 进行基础性操作的命令&#xff0c;对 Key 的操作命令&#xff0c;对 Value 的操作命令。 3.1 Redis 基本命令 一些可选项对大小写敏感, 所以应尽量将redis的所有命令大写输入 首先通过 redis-…...

go语言函数进阶

1.变量作用域 全局变量 全局变量是定义在函数外部的变量&#xff0c;它在程序整个运行周期内都有效。 在函数中可以访问到全局变量。 package mainimport "fmt"//定义全局变量num var num int64 10func testGlobalVar() {fmt.Printf("num%d\n", num) /…...

Python编程技巧 – 函数参数

Python编程技巧 – 函数参数 Python Programming Skills - Functional Parameters 1. 函数的定义 函数有简明扼要的定义。 函数是一个代码块&#xff0c;仅在调用时运行。可以将数据&#xff08;称为参数&#xff09;传递到函数中。函数可以返回数据作为结果。 2. 函数的结…...

python222网站实战(SpringBoot+SpringSecurity+MybatisPlus+thymeleaf+layui)-帖子管理实现

锋哥原创的SpringbootLayui python222网站实战&#xff1a; python222网站实战课程视频教程&#xff08;SpringBootPython爬虫实战&#xff09; ( 火爆连载更新中... )_哔哩哔哩_bilibilipython222网站实战课程视频教程&#xff08;SpringBootPython爬虫实战&#xff09; ( 火…...

LabVIEW扫频阻抗测试系统

实现扫频阻抗法用于检测变压器绕组变形&#xff0c;结合了短路阻抗法和频响法的优点&#xff0c;但受限于硬件精度&#xff0c;尤其是50 Hz短路阻抗测试存在稳定性和准确性的问题。通过LabVIEW编程&#xff0c;控制宽频带信号发生器和高速采集卡&#xff0c;提高测试结果的稳定…...

C语言——指针进阶(四)

目录 一.前言 二.指针和数组笔试题解析 2.1 二维数组 2.2 指针笔试题 三.全部代码 四.结语 一.前言 本文我们将迎来指针的结尾&#xff0c;包含了二维数组与指针的试题解析。码字不易&#xff0c;希望大家多多支持我呀&#xff01;&#xff08;三连&#xff0b;关注&…...

Django介绍

一、介绍 Django是Python语言中的一个Web框架&#xff0c;Python语言中主流的web框架有Django、Tornado、Flask 等多种 优势&#xff1a;大而全&#xff0c;框架本身集成了ORM、模型绑定、模板引擎、缓存、Session等功能&#xff0c;是一个全能型框架&#xff0c;拥有自己的A…...

【idea】几个不错的idea插件让我码速又快了

目录 前言 Gradianto插件 jclasslib Bytecode viewer插件 Grep Console 插件 GenerateAllSetter 插件 GsonFormat 插件 JRebel and XRebel 插件 leetcode editor 插件 maven helper 插件 SequenceDiagram 插件 Statistic 插件 Translation 插件 前言 idea可以说是j…...

LabVIEW直流电机转速检测与控制

研究了使用LabVIEW软件和ELVIS实验平台来检测和控制直流电机的转速。通过集成光电传感器和霍尔传感器&#xff0c;实现了对电机转速的精确测量和调节。 系统组成&#xff1a;系统由NI ELVIS实验平台、光电传感器、霍尔传感器和直流电机组成。通过这些硬件元件&#xff0c;系统…...

༺༽༾ཊ—Unity之-05-抽象工厂模式—ཏ༿༼༻

首先创建一个项目&#xff0c; 在这个初始界面我们需要做一些准备工作&#xff0c; 建基础通用文件夹&#xff0c; 创建一个Plane 重置后 缩放100倍 加一个颜色&#xff0c; 任务&#xff1a;使用 抽象工厂模式 创建 人物与宠物 模型&#xff0c; 首先资源商店下载 人物与宠物…...

力扣面试题02.07-链表相交

链表相交 题目链接 解题思路&#xff1a; 题目可以确定如果相交&#xff0c;那么相交的部分一定是在链表的结尾部分第一步求得两条链表的长度第二步长度做差&#xff0c;将长的那条链表与短的那条链表后部分对其第三步遍历后面的部分&#xff0c;如果当前节点相等&#xff0c;…...