【C语言】扫雷小游戏初学者版

news2024/12/22 19:56:40

在这里插入图片描述
成功的秘诀就是每天都比别人多努力一点。
今天给大家带来一款非常经典的小游戏——扫雷的实现和讲解

这里是目录

  • 前言
  • 整体框架
  • 1.打印菜单
  • 2.创建二维数组
  • 3.初始化棋盘
  • 4.打印棋盘
  • 5.布置棋盘中的雷
  • 6.排查雷和统计雷
  • 总体代码
    • test.c
    • game.c
    • game.h
  • 进阶(递归展开)

前言

在开始之前我们先来了解一下扫雷游戏的实现流程。
在这里插入图片描述

了解了游戏的基本流程,接下来我们就要跟着流程一步一步实现功能

整体框架

//test.c
void test()
{
	int input = 0;
	do
	{
		menu();//菜单函数
		printf("请选择->");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			game();//游戏函数
			break;
		case 0:
			printf("退出游戏\n");
			break;
		default:
			printf("选择错误,请重新选择\n");
			break;
		}
	} while (input);
}
int main()
{
	test();
	return 0;
}

整体框架和之前讲过的猜数字小游戏一致,如有不了解的地方可以前往猜数字小游戏进行了解

1.打印菜单

void menu()
{
	printf("****************************\n");
	printf("********   1.play   ********\n");
	printf("********   0.exit   ********\n");
	printf("****************************\n");
}

有了菜单我们就可以写game函数了,那么game函数怎么实现呢?
我们来分析一下:我们的下一步是要布置雷,但是布置雷之前是不是得有一个数组?
所以我们的下一步就是创建一个二维数组

2.创建二维数组

我们先创建一个9*9的二维数组,并布置雷。
在这里插入图片描述

假设“1”是我们布置好的雷,布置好雷后我们跟着流程继续往下走
接下来就是排查雷
那么我们在排查雷之前回去看一遍这个二维数组,如果我们在这个二维数组里进行排查会不会出现什么问题呢?
我们来试验一下
在这里插入图片描述
当我们把雷的个数打印出来的时候就出现问题了,这个"1"到底是排查出来他周围有"1"个雷的"1"呢?还是这个"1"是雷?
那我们能不能把雷改成" * “或者” # "呢?
答案是可行的,但是不建议这么做,这会让后面一些功能的实现变得困难,我们接着往下看
既然这样做会产生歧义,那我们应该怎么修改呢?
其实很简单
我们只需要创建2个二维数组就可以解决这个问题,1个二维数组用来存放雷的坐标,另一个二维数组用来存放排查出的雷的信息,这样我们在进行游戏的时候只需要打印排查出的雷的信息的数组就可以了
让我们再来分析一遍这个数组
在这里插入图片描述
如果我们每次统计都要对坐标的合法性进行判断,这就会非常的麻烦,那么怎么办呢?
方法也很简单,我们只需要在棋盘周围多创建 2行2列(11*11的数组) 就可以了,这样就不会有数组越界的情况发生了

定义棋盘大小:

//game.h
//定义mine数组的行和列的大小为:9
#define ROWM 9
#define COLM 9
//定义show数组的行和列的大小为mine数组的行/列+2
#define ROWS ROWM + 2
#define COLS COLM + 2

创建棋盘:

//test.c
void game()
{
	//1.需要存放布置好的雷的信息和排查雷的信息,所以需要2个数组
	char mine[ROWS][COLS] = { 0 };//布置好的雷
	char show[ROWS][COLS] = { 0 };//排查出的雷

}

如果show数组创建成9X9那么排查的时候需要计算数组的坐标太麻烦,所以我们把show数组也创建成11X11这样排查的坐标就可以直接套用
但实际只显示出9X9的棋盘
在这里插入图片描述

3.初始化棋盘

现在我们希望mine数组全部初始化为0,show数组全部初始化为*
我们可以写一个初始化函数来实现这个功能

game.h

//定义数组的行和列的大小
#define ROW 9
#define COL 9
#define ROWS ROW + 2
#define COLS COL + 2

//声明初始化棋盘
void InitBoard(char board[ROWS][COLS], int rows, int cols, char set);

test.c

void game()
{
	//1.需要存放布置好的雷的信息和排查雷的信息,所以需要2个数组
	char mine[ROWS][COLS] = { 0 };//布置好的雷

	//如果show数组创建成9X9那么排查的时候需要计算数组的坐标太麻烦
	//所以我们把show数组也创建成11X11这样排查的坐标就可以直接套用
	//但实际只显示出9X9的棋盘
	char show[ROWS][COLS] = { 0 };//排查出的雷

	//传递棋盘,行和列,希望初始化的字符
	InitBoard(mine, ROWS, COLS, '0');
	InitBoard(show, ROWS, COLS, '*');

}

game.c

//初始化棋盘的实现
void InitBoard(char board[ROWS][COLS], int rows, int cols, char set)
{
	int i = 0;
	for (i = 0; i < ROWS; i++)
	{
		int j = 0;
		for (j = 0; j < COLS; j++)
		{
			board[i][j] = set;
		}
	}
}

这样棋盘就初始化好了,那我们现在还需要一个打印函数来查看棋盘的状态

4.打印棋盘

打印函数的实现:
注意:我们只需要打印9X9的数组,而非11X11,但是在接收数组的时候要用11X11的数组接收

game.h

//打印棋盘声明
void DisplayBoard(char board[ROWS][COLS], int row, int col);

game.c

void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
	//注意:传递的数组是11X11的,并非9X9
	int i = 1;
	for (i = 1; i <= row; i++)
	{
		int j = 1;
		for (j = 1; j <= col; j++)
		{
			printf("%c ", board[i][j]);
		}
		//打印完一行后换行
		printf("\n");
	}
}

test.c中的game函数

void game()
{
	//1.需要存放布置好的雷的信息和排查雷的信息,所以需要2个数组
	char mine[ROWS][COLS] = { 0 };//布置好的雷

	//如果show数组创建成9X9那么排查的时候需要计算数组的坐标太麻烦
	//所以我们把show数组也创建成11X11这样排查的坐标就可以直接套用
	//但实际只显示出9X9的棋盘
	char show[ROWS][COLS] = { 0 };//排查出的雷

	//传递棋盘,行和列,希望初始化的字符
	InitBoard(mine, ROWS, COLS, '0');
	InitBoard(show, ROWS, COLS, '*');

	//打印棋盘
	DisplayBoard(mine, ROW, COL);
	DisplayBoard(show, ROW, COL);
}

运行效果:
在这里插入图片描述
可以看到,我们的棋盘成功打印了,但是不难发现,我们很难确定行和列的坐标,所以我们还需要对打印函数进行优化
注:这里我们并不要打印mine数组,这里打印只是为了演示

优化后的打印函数:

void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
	//注意:传递的数组是11X11的,并非9X9
	int i = 1;
	int j = 1;
	printf("--------扫雷--------\n");
	//打印列号
	for (j = 0; j <= col; j++)
	{
		printf("%d ", j);
	}
	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");

}

运行效果:

在这里插入图片描述


5.布置棋盘中的雷

有了棋盘我们接下来要做的就是布置雷

布置雷的思路是布置到中间9X9的数组中,红色方框的位置
注意:传递的数组依旧为11X11,只是我们只用了其中的9X9,所以接收的数组也要用11X11来接收
在这里插入图片描述
我们需要在棋盘上随机布置雷,需要生成随机坐标(rand函数),我们就假定棋盘中只有10个雷

可以用#define来定义雷的个数,方便以后修改难度,我这边就定死为10个,自己实现的时候建议#define定义

game.h

//布置雷函数的声明
void SetMine(char mine[ROWS][COLS], int row, int col);

game.c

//布置雷函数的实现
void SetMine(char mine[ROWS][COLS], int row, int col)
{
	//雷的个数
	int count = 10;
	
	while (count)
	{
		//生成随机下标
		//注意行和列都是从1开始的
		//rand函数需要初始化,在test函数开头加上srand((unsigned int)time(NULL));
		int x = rand() % row + 1;
		int y = rand() % col + 1;

		//布置雷
		//判断坐标是否有雷
		if (mine[x][y] == '0')
		{
			//注意赋值不要写成:==
			mine[x][y] = '1';
			count--;
		}
	}
}

这样十颗雷就布置好了,打印出来看看效果:
在这里插入图片描述


6.排查雷和统计雷

有了棋盘,有了雷之后我们就可以排查雷了
排雷的参数和之前的一致,还是11X11中间的9X9
统计雷的思路:
在这里插入图片描述

game.h

//排查雷函数的声明
void FindMind(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);

game.c

//统计雷函数的实现
int get_mine_count(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 FindMind(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{
	int x = 0;
	int y = 0;
	//记录排查过的不是雷的个数
	int win = 0;
	//如果所有不为雷的个数都被排查过,游戏胜利
	while(win < (row * col - 10))
	{
		printf("请输入要排查的坐标->");
		//输入坐标
		scanf("%d %d", &x, &y);

		//判断坐标是否合法
		if (x >= 1 && x <= row && y >= 1 && y <= col)
		{
			//判断坐标是否被排查过
			if (show[x][y] != '*')
			{
				printf("该坐标已被排查\n");
				continue;
			}
			//判断是否为雷
			if (mine[x][y] == '1')
			{
				printf("坐标为雷,游戏结束\n");
				DisplayBoard(mine, ROW, COL);
				break;
			}
			else
			{
				//统计坐标周围的雷
				int n = get_mine_count(mine, x, y);
				//注意返回的是int,我们棋盘的类型是char,所以需要转换
				show[x][y] = n + '0';
				DisplayBoard(show, ROW, COL);
				win++;
			}
		}
		else
		{
			printf("无效的坐标,请重新输入\n");
		}
	}
	if (win == (row * col - 10))
	{
		printf("游戏胜利\n");
		DisplayBoard(mine, ROW, COL);
	}
}

这样,我们的扫雷游戏就实现好了

运行效果:
在这里插入图片描述

总体代码

test.c

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include "game.h"

void menu()
{
	printf("****************************\n");
	printf("********   1.play   ********\n");
	printf("********   0.exit   ********\n");
	printf("****************************\n");
}

void game()
{
	//1.需要存放布置好的雷的信息和排查雷的信息,所以需要2个数组
	char mine[ROWS][COLS] = { 0 };//布置好的雷

	//如果show数组创建成9X9那么排查的时候需要计算数组的坐标太麻烦
	//所以我们把show数组也创建成11X11这样排查的坐标就可以直接套用
	//但实际只显示出9X9的棋盘
	char show[ROWS][COLS] = { 0 };//排查出的雷

	//传递棋盘,行和列,希望初始化的字符
	InitBoard(mine, ROWS, COLS, '0');
	InitBoard(show, ROWS, COLS, '*');

	//打印棋盘
	DisplayBoard(show, ROW, COL);
	//DisplayBoard(mine, ROW, COL);

	//布置雷
	SetMine(mine, ROW, COL);
	
	//排查雷
	FindMind(mine, show, ROW, COL);
}

void test()
{
	srand((unsigned int)time(NULL));
	int input = 0;
	do
	{
		menu();//菜单函数
		printf("请选择->");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			game();//游戏函数
			break;
		case 0:
			printf("退出游戏\n");
			break;
		default:
			printf("选择错误,请重新选择\n");
			break;
		}
	} while (input);
}

int main()
{
	test();
	return 0;
}

game.c

#include "game.h"

//初始化棋盘函数的实现
void InitBoard(char board[ROWS][COLS], int rows, int cols, char set)
{
	int i = 0;
	for (i = 0; i < ROWS; i++)
	{
		int j = 0;
		for (j = 0; j < COLS; j++)
		{
			board[i][j] = set;
		}
	}
}

//打印棋盘函数的实现
void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
	//注意:传递的数组是11X11的,并非9X9
	int i = 1;
	int j = 1;
	printf("--------扫雷--------\n");
	//打印列号
	for (j = 0; j <= col; j++)
	{
		printf("%d ", j);
	}
	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 SetMine(char mine[ROWS][COLS], int row, int col)
{
	//雷的个数
	int count = 10;
	
	while (count)
	{
		//生成随机下标
		//注意行和列都是从1开始的
		int x = rand() % row + 1;
		int y = rand() % col + 1;

		//布置雷
		//判断坐标是否有雷
		if (mine[x][y] == '0')
		{
			mine[x][y] = '1';
			count--;
		}
	}
}

//统计雷函数的实现
int get_mine_count(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 FindMind(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{
	int x = 0;
	int y = 0;
	//记录排查过的不是雷的个数
	int win = 0;
	//如果所有不为雷的个数都被排查过,游戏胜利
	while(win < (row * col - 10))
	{
		printf("请输入要排查的坐标->");
		//输入坐标
		scanf("%d %d", &x, &y);

		//判断坐标是否合法
		if (x >= 1 && x <= row && y >= 1 && y <= col)
		{
			//判断坐标是否被排查过
			if (show[x][y] != '*')
			{
				printf("该坐标已被排查\n");
				continue;
			}
			//判断是否为雷
			if (mine[x][y] == '1')
			{
				printf("坐标为雷,游戏结束\n");
				DisplayBoard(mine, ROW, COL);
				break;
			}
			else
			{
				//统计坐标周围的雷
				int n = get_mine_count(mine, x, y);
				//注意返回的是int,我们棋盘的类型是char,所以需要转换
				show[x][y] = n + '0';
				DisplayBoard(show, ROW, COL);
				win++;
			}
		}
		else
		{
			printf("无效的坐标,请重新输入\n");
		}
	}
	if (win == (row * col - 10))
	{
		printf("游戏胜利\n");
		DisplayBoard(mine, ROW, COL);
	}
}

game.h

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

//定义mine数组的行和列的大小为:9
#define ROW 9
#define COL 9
//定义show数组的行和列的大小为mine数组的行/列+2
#define ROWS ROW + 2
#define COLS COL + 2

//声明初始化棋盘
void InitBoard(char board[ROWS][COLS], int rows, int cols, char set);

//打印棋盘声明
void DisplayBoard(char board[ROWS][COLS], int row, int col);

//布置雷函数的声明
void SetMine(char mine[ROWS][COLS], int row, int col);

//排查雷函数的声明
void FindMind(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);

进阶(递归展开)

递归展开函数的作用是为了达到周围没雷时直接展开周围所有空间,利用递归不断向外展开,直至周围有雷为止
代码如下:
添加is_win函数和Exp函数并修改FindMind函数逻辑即可

//判断是否胜利
int is_win(char show[ROWS][COLS])
{
	int count1 = 0;
	int i = 0, j = 0;
	for (i = 1; i <= ROW; i++)
	{
		for (j = 1; j <= COL; j++)
		{
			if (show[i][j] != '*')
			{
				count1++;
			}
		}
	}
	return count1;
}

//递归展开函数
Exp(char mine[ROWS][COLS], char show[ROWS][COLS], int x, int y)
{

	if (x >= 1 && x <= ROW && y >= 1 && y <= COL)//防止越界
	{
		int count = get_mine_count(mine, x, y);//获取该位置周围雷数
		if (count == 0)//周围没雷
		{
			show[x][y] = ' ';//赋值为空字符
			int i = 0, j = 0;
			for (i = x - 1; i <= x + 1; i++)//限制行
			{
				for (j = y - 1; j <= y + 1; j++)//限制列
				{
					if (show[i][j] == '*' && (i != x || j != y))//防止重复访问
					{
						Exp(mine, show, i, j);//递归调用
					}

				}
			}
		}
		else
		{
			show[x][y] = count + '0';//显示雷数
		}
	}
}

//排查雷的实现
void FindMind(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{
	//可以在适当的位置加入清屏函数来实现界面整洁:system("cls");
	int x = 0;
	int y = 0;
	//记录排查过的不是雷的个数
	int win = 0;
	//如果所有不为雷的个数都被排查过,游戏胜利
	while(win < (row * col - 10))
	{
		printf("请输入要排查的坐标->");
		//输入坐标
		scanf("%d %d", &x, &y);

		//判断坐标是否合法
		if (x >= 1 && x <= row && y >= 1 && y <= col)
		{
			//判断坐标是否被排查过
			if (show[x][y] != '*')
			{
				printf("该坐标已被排查\n");
				continue;
			}
			//判断是否为雷
			if (mine[x][y] == '1')
			{
				printf("坐标为雷,游戏结束\n");
				DisplayBoard(mine, ROW, COL);
				break;
			}
			else
			{
				//统计坐标周围的雷
				Exp(mine, show, x, y);
				win = is_win(show);
				DisplayBoard(show, ROW, COL);
			}
		}
		else
		{
			printf("无效的坐标,请重新输入\n");
		}
	}
	if (win == (row * col - 10))
	{
		printf("游戏胜利\n");
		DisplayBoard(mine, ROW, COL);
	}
}

递归展开运行效果:
在这里插入图片描述

以上就是本篇文章的全部内容了,希望大家看完能有所收获

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

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

相关文章

【arduino库之TroykaDHT(针对DHT系列温湿度传感器)】

该库允许您从 DHT 系列传感器读取温度和湿度。 该库允许获取以摄氏度、开尔文和华氏度为单位的相对湿度和温度数据。支持的传感器&#xff1a;DH11、DHT21、DHT22。 TroykaDHT库的的使用非常简单&#xff0c;它包含7个函数&#xff1a; begin //初始化接口&#xff0c;做好…

Matlab 生成license

参考下面两个帖子 https://ww2.mathworks.cn/matlabcentral/answers/389888-matlab https://www.mathworks.com/matlabcentral/answers/131749-id-id-id-id 登陆 https://ww2.mathworks.cn/licensecenter 针对R2020b版本,点击下面红框生成 ip addr | grep ether看第一行 根据…

如何使用cpolar+Plex在Windows系统上搭建私人媒体影音站点公网可访问

文章目录 1.前言2. Plex网站搭建2.1 Plex下载和安装2.2 Plex网页测试2.3 cpolar的安装和注册 3. 本地网页发布3.1 Cpolar云端设置3.2 Cpolar本地设置 4. 公网访问测试5. 结语 1.前言 用手机或者平板电脑看视频&#xff0c;已经算是生活中稀松平常的场景了&#xff0c;特别是各…

数据可视化私有化部署:为何成本居高不下?

尽管在可视化设计这行干了好多年&#xff0c;也接手过不少项目&#xff0c;但昂贵的私有化部署费用总能让我发出由衷的感叹&#xff1a;“这几十万一年也太贵了&#xff01;”。可以预见&#xff0c;数据可视化软件私有化部署所带来的高昂成本&#xff0c;将是许多企业面临的问…

探索数据之美:优雅权重计算方法与Python实践

写在开头 在数据的世界里,我们常常需要通过各种方法为不同的数据点分配合理的权重。这是数据分析中至关重要的一环,它决定了模型的准确性和结果的可信度。本文将引导您探索数据分析中常用的权重计算方法,并通过清晰的Python代码实现,让您轻松驾驭权重的奥秘。 1.常见分类…

人机交互——言语信息表示模型

如何将大量的言语碎片进行统一表示和存储&#xff0c;以便能够提取不同类型言语信息中的重要特征和语义信息&#xff0c;并计算和推理用户的交互意图&#xff0c;是一个极具挑战性的问题。 1.言语信息表示模型概述 2.言语信息表示模型结构 3.言语信息表示模型应用

什么是网络爬虫?有什么用?怎么爬?

嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 【导读】 网络爬虫也叫做网络机器人&#xff0c;可以代替人们自动地在互联网中进行数据信息的采集与整理。 在大数据时代&#xff0c;信息的采集是一项重要的工作&#xff0c;如果单纯靠人力进行信息采集&#xff0c;不仅低…

认识Docker

Docker 是世界领先的软件容器平台&#xff0c;所以想要搞懂 Docker 的概念我们必须先从容器开始说起。 1.1 什么是容器? 先来看看容器较为官方 一句话概括容器&#xff1a;容器就是将软件打包成标准化单元&#xff0c;以用于开发、交付和部署。 容器镜像是轻量的、可执行的…

跨境卖家2023圣诞节攻略:激发购物热情,海外网红营销大作战

随着全球电商的快速发展&#xff0c;跨境卖家们正面临着越来越激烈的竞争。在这个竞争激烈的市场中&#xff0c;如何通过有效的营销策略吸引目标受众&#xff0c;成为跨境卖家需要认真思考的问题之一。尤其是在圣诞节这个全球性的购物狂欢节&#xff0c;海外网红营销成为了一种…

12月第一天,给搞电商的家人们整活儿!

今年&#xff0c;大家出门的热情直线飙升&#xff01; 特种兵旅游带火N个小众城市、Citywalk大军激活大街小巷的商业活力、线下演出火爆带动各地文旅指数狂飙&#xff0c;户外运动也乘风而上&#xff0c;徒步/露营/钓鱼/骑行/冲浪/滑雪等花式运动在各大社媒平台集中刷屏&#…

接口验签规则

一、验签的背景 在网络发展快速的过程中&#xff0c;总是会忽略接口数据安全问题&#xff0c;进行验签则能够在一定程度上能够防刷&#xff0c;数据篡改。 二、什么是加签验签 加签验签&#xff0c; 发送消息方&#xff0c;对消息加签名&#xff1b; 接受消息方&#xff0…

记一次引入低版本包导致包冲突,表现为NoClassDefFoundError的故障

简而言之&#xff0c;因为参考别的项目处理excel的代码if(org.apache.poi.hssf.usermodel.HSSFDateUtil.isCellDateFormatted(cell)) &#xff0c;为了使用这个HSSFDateUtil类我引入了依赖&#xff1a; <dependency><groupId>org.apache.poi</groupId><a…

探索 Linux Namespace:Docker 隔离的神奇背后

来自&#xff1a;探索云原生 https://www.lixueduan.com 原文&#xff1a;https://www.lixueduan.com/posts/docker/03-container-core/ 在 深入理解 Docker 核心原理&#xff1a;Namespace、Cgroups 和 Rootfs 一文中我们分析了 Docker 是由三大核心技术实现的。 今天就一起分…

【ARM Trace32(劳特巴赫) 使用介绍 12 -- Trace32 常用命令之 d.dump | data.dump 介绍】

文章目录 Trace32 常用命令之 d.dump | data.dump 介绍1 字节显示 (Byte)4 字节显示&#xff08;word&#xff09;8 字节显示&#xff08;通常long&#xff09;十进制显示显示指定列数显示地址范围内的值 Trace32 常用命令之 d.dump | data.dump 介绍 在 TRACE32 调试环境中&a…

S32K116新建工程Debug可以运行,冷启动无法运行问题分析

S32K116使用IAR建立工程后&#xff0c;软件debug可以运行&#xff0c;断电冷启动无法运行。 这种现象基本上都是RAM未初始化导致&#xff0c;由于Debug时&#xff0c;调试器会自动初始化芯片&#xff0c;很多问题都不会暴露处理。 大家可以开一下Startup的汇编文件&#xff0c;…

羊大师教你如何在冬天运动,然后悄悄惊艳所有人

羊大师教你如何在冬天运动&#xff0c;然后悄悄惊艳所有人 寒冷的冬季&#xff0c;寂静的清晨&#xff0c;你是否也曾感到在冰冷的天气中进行锻炼是一件非常困难的事情&#xff1f;但是&#xff0c;现在请跟随小编羊大师一起来探索冬季秘密运动&#xff0c;让你在春节惊艳众人…

XC4060 40V降5V/3.3V 0.6A小电流高耐压芯片 适用于单片机供电输出、电池供电设备

XC4060器件是高效率&#xff0c;同步降压DC/DC稳压器。具有较宽的输入范围&#xff0c;它们适用于广泛的应用&#xff0c;例如来自非稳压源的功率调节。他们的特点是一个长距离(500mQ/300mQ2型) 内部开关的效率最高 (92%)。Sum od (非A选项)和PWM模式(A选项)&#xff0c;工作频…

Windows server 2019 域环境部署

环境准备 准备3台服务器&#xff0c;配置都是8g2核&#xff0c;50g硬盘&#xff0c;操作系统版本Windows Server 2019 Datacenter 域服务器&#xff1a;adc&#xff0c;192.168.56.120服务器1&#xff1a;server1:&#xff0c;192.168.56.121服务器2&#xff1a;server2&…

如何使用gdb调试fork程序

代码示例 #include<stdio.h> #include<unistd.h> #include<sys/types.h> #include<stdlib.h> #include<sys/wait.h>int main(int argc, const char* argv[]) {pid_t pid -1;int status 0;int ret -1; // 创建子进程。若创建成功&#xff0c;…

MySQL基础『数据类型』

✨个人主页&#xff1a; 北 海 &#x1f389;所属专栏&#xff1a; MySQL 学习 &#x1f383;操作环境&#xff1a; CentOS 7.6 阿里云远程服务器 &#x1f381;软件版本&#xff1a; MySQL 5.7.44 文章目录 1.数据类型一览2.整型2.1.INT2.2.BIT 3.浮点数3.1.FLOAT3.2.DECIMAL3…