(C语言)球球大作战

  前言:

这款简易版的球球大作战是一款单人游戏,玩家需要控制一个小球在地图上移动,吞噬其他小球来增大自己的体积。本游戏使用C语言和easyx图形库编写,旨在帮助初学者了解游戏开发的基本概念和技巧。

在开始编写代码之前,我们需要先了解一下游戏的基本规则和功能:

游戏界面:游戏界面是一个矩形区域,玩家可以在这个区域内控制球的移动。

玩家小球:玩家控制的小球可以在游戏界面内自由移动,按下空格键可以加速。

其他小球:其他小球又分为食物小球,和ai控制的小球

体积:玩家每吃一个其他小球体积就会增大一点,ai小球也可以通过吃食物和玩家小球增大体积。

玩家被吃:当玩家小球被ai小球吃了,玩家小球就会回到初始点,体积也会变成初始大小。

ai小球的追击和逃跑:当玩家小球与ai小球靠近时,ai小球会根据自身体积的大小选择追击玩家小球或者逃跑。

接下来,我们将通过以下几个步骤来实现这个游戏:

初始化游戏界面和小球的信息。

处理键盘输入,实现玩家小球的移动和加速。

生成足够数量的食物小球。

生成ai小球,并控制其移动。

检测小球之间的吞噬关系,增加相应的体积。

通过学习这个游戏的开发过程,初学者将能够掌握C语言编程和easyx图形库的基本技巧。

1. 小球的要素

在此游戏中一个小球的要素无非就是小球所在的位置(坐标)、小球的半径、以及小球的颜色,这里我们可以用一个结构体数组来存放这些要素,以方便初始化小球的信息。

struct Ball
{int x;int y;float r;DWORD color;
};

2. 初始化小球的信息

将玩家小球的初始位置设置在窗口的中间,半径大小为10。食物小球和ai小球的位置则通过rand函数、srand函数和time函数生成的随机数,随机分布在地图的各个位置,食物小球半径为1-5,ai小球的半径10.其中在这里使用了RGB随机生成一个颜色,使每个食物小球的颜色都不尽相同。

RGB色彩模式是一种工业标准,它通过红(R)、绿(G)、蓝(B)三个颜色通道的组合来表示不同的颜色。每个通道通常分配一个0到255之间的数值,其中0表示该颜色通道没有亮度,255表示该颜色通道的最大亮度。通过调整这三个通道的值,可以生成几乎所有人类视觉系统能够感知的颜色。例如:

  • 橙色可以通过RGB值(255, 128, 0)来表示。
  • 黄色的RGB值为(255, 255, 0)。
  • 绿色的RGB值是(0, 255, 0)。
  • 蓝色的RGB值为(0, 0, 255)。
  • 紫色可以通过RGB值(170, 0, 255)来表示。
  • 黑色的RGB值为(0, 0, 0)。
  • 白色的RGB值为(255, 255, 255)。
  • 灰色的RGB值可以是(128, 128, 128),其中三个值相等即可,值越接近255,颜色就越接近白色,反之亦然。
void Inset()
{//玩家小球srand((unsigned)time(NULL));player.x = Wide / 2;player.y = Hight / 2;player.r = 10;//食物小球for (int i = 0; i < Food_num; i++){Food[i].x = rand() % Wide_map;Food[i].y = rand() % Hight_map;Food[i].r = rand() % 5 + 1;Food[i].color = RGB(rand() % 256, rand() % 256, rand() % 256);}//ai小球for (int i = 0; i < Enemy_num; i++){Enemy[i].x = rand() % Wide_map;Enemy[i].y = rand() % Hight_map;Enemy[i].r = 10;Enemy[i].color = RGB(0,255,0);}}

3. 玩家操作小球

在这里需要用到GetAsyncKeyState(vk virtual key)函数获取异步按键状态,其中vk virtual key是虚拟键值,如果接受到这个虚拟键值,它会返回真。VK_UP、VK_DOWN、VK_LEFT、VK_RIGHT、0x20分别是上箭头键、下箭头键、左箭头键、右箭头键、空格键的虚拟键值。

void Player_move()
{if (GetAsyncKeyState(VK_UP)){if (player.y > 0){player.y -= player_sleep;}}if (GetAsyncKeyState(VK_DOWN)){if (player.y < Hight_map)player.y += player_sleep;}if (GetAsyncKeyState(VK_LEFT)){if (player.x > 0)player.x -= player_sleep;}if (GetAsyncKeyState(VK_RIGHT)){if (player.x < Wide_map)player.x += player_sleep;}if (GetAsyncKeyState(0x20)){player_sleep = l + 5;}else{player_sleep = l;}
}

4. 显示出小球

在此游戏中,小球是一个实心圆,在easyx图形库中提供了一个画实心圆的函数—solidcircle函数,通过它我们就可以在窗口中显示小球了,但显示出的小球默认颜色为白色,为了区分不同的小球,我们还需使用setfillcolor函数来改变小球的颜色。因为显示的函数、玩家操作小球的函数等函数都是放在同一个while循环重复执行的,这样就会重复显示小球,所以我们还需要用到一个清屏函数cleardevice。为了使窗口更好看可以使用setbkcolor函数修改窗口的背景颜色,以及使用line函数在窗口中画一些线,函数setlinecolor可以改变线的颜色。

void Show()
{//设置地图SetWorkingImage(&map);//清屏cleardevice();//背景颜色setbkcolor(WHITE);//划线颜色setlinecolor(RGB(230,231,239));//划线for (int i = 0; i < Wide_map; i += 10){line(i, 0, i, Hight_map);}for (int i = 0; i < Hight_map; i += 10){line(0, i, Wide_map, i);}//食物for (int i = 0; i < Food_num; i++){setfillcolor(Food[i].color);solidcircle(Food[i].x, Food[i].y, Food[i].r);}//敌人for (int i = 0; i < Enemy_num; i++){setfillcolor(Enemy[i].color);solidcircle(Enemy[i].x, Enemy[i].y, Enemy[i].r);}//玩家setfillcolor(RED);solidcircle(player.x, player.y, player.r);SetWorkingImage();int x = player.x - (Wide / 2);int y = player.y - (Hight / 2);//防止窗口越界if (x < 0){x = 0;}if (y < 0){y = 0;}if (x > Wide_map - Wide){x = Wide_map - Wide;}if (y > Hight_map - Hight){y = Hight_map - Hight;}//把map输出到窗口上putimage(0, 0, Wide, Hight, &map, x, y);
}

5. 生成地图

可以使用IMAGE map(Wide_map, Hight_map) 创建一个图像映射,其中 Wide_map 代表图像的宽度,而 Hight_map 代表图像的高度。然后使用SetWorkingImage(&map),将map的地址作为参数传递给SetWorkingImage函数。这个函数的作用是将map作为当前操作的对象,以便在后续的图像处理过程中使用。最后使用putimage(0, 0, Wide, Hight, &map, x, y) 将地址绘制到窗口上,其中要让玩家小球始终出现在窗口的中央位置,那么其中的x=player.x - (Wide / 2);y=player.y - (Hight / 2);但是单单这样写就会出现窗口越界的情况,所以我们还需要限制x和y的范围:

//防止窗口越界
if (x < 0)
{x = 0;
}
if (y < 0)
{y = 0;
}
if (x > Wide_map - Wide)
{x = Wide_map - Wide;
}
if (y > Hight_map - Hight)
{y = Hight_map - Hight;
}

putimage(0, 0, Wide, Hight, &map, x, y) 这个函数调用是用于在屏幕上的特定位置绘制或显示一个图像。下面是对这个函数调用中各个参数的具体解释:

  1. (0, 0):这是图像要绘制的目标位置的左上角坐标,即x=0和y=0,通常表示屏幕的左上角。

  2. Wide:这个参数指定了要绘制的图像的宽度。

  3. Hight:这个参数指定了要绘制的图像的高度。

  4. &map:这是一个指向图像内存地址的指针,该图像将被绘制到屏幕上。在这个上下文中,map可能是一个包含了图像数据的数据结构或数组。

  5. x:这个参数通常指定了要开始绘制图像的起始点的x坐标(在图像数据中)。

  6. y:这个参数通常指定了要开始绘制图像的起始点的y坐标(在图像数据中)。

6. ai小球的移动

随机生成0-3的数字分别代表ai小球上下左右的移动,这样小球就会自由移动了。当玩家小球与ai小球靠近时,ai小球会追击或者逃跑,这里我们需要先计算小球的之间的距离,小球之间的距离就是两小球的圆心坐标的x相减的平方加上y相减的平方再开根号。开根号的函数为sqrt,它的头文件是<math.h>。

//距离
int Distance(int x, int y, int x1, int y1)
{return sqrt((x - x1) * (x - x1) + (y - y1) * (y - y1));
}

然后判断两小球的距离是否小于50个像素点,即判断是否小于玩家小球的半径 + ai小球的半径 + 50。判断完后比较两小球的半径大小,如果ai小球的半径大于玩家小球的半径,那么ai小球就要追击玩家小球,即ai小球的坐标需要靠近玩家小球的坐标,就是如果ai小球的x大于玩家小球的x那么ai小球的x就减小,同理可得剩下的操作。

void Enemy_move()
{srand((unsigned)time(NULL));for (int i = 0; i < Enemy_num; i++){int direction = rand() % 4;if (Distance(player.x, player.y, Enemy[i].x, Enemy[i].y) > player.r + Enemy[i].r + 50){if (direction == 0){if (Enemy[i].y > 0)//防止小球越界的判断语句{Enemy[i].y -= enemy_sleep;}}if (direction == 1){if (Enemy[i].y < Hight_map)Enemy[i].y += enemy_sleep;}if (direction == 2){if (Enemy[i].x > 0)Enemy[i].x -= enemy_sleep;}if (direction == 3){if (Enemy[i].x < Wide_map)Enemy[i].x += enemy_sleep;}}//敌人追击玩家if (Distance(player.x, player.y, Enemy[i].x, Enemy[i].y) < player.r + Enemy[i].r + 50){if (Enemy[i].r > player.r){if (Enemy[i].x < player.x){if (Enemy[i].x < Wide_map){Enemy[i].x += enemy_sleep;}}if (Enemy[i].x > player.x){if (Enemy[i].x > 0){Enemy[i].x -= enemy_sleep;}}if (Enemy[i].y < player.y){if (Enemy[i].y < Hight_map){Enemy[i].y += enemy_sleep;}}if (Enemy[i].y > player.y){if (Enemy[i].y > 0){Enemy[i].y -= enemy_sleep;}}}//敌人逃跑else{if (Enemy[i].x < player.x){if (Enemy[i].x > 0){Enemy[i].x -= enemy_sleep;}}if (Enemy[i].x > player.x){if (Enemy[i].x < Wide_map){Enemy[i].x += enemy_sleep;}}if (Enemy[i].y < player.y){if (Enemy[i].y > 0){Enemy[i].y -= enemy_sleep;}}if (Enemy[i].y > player.y){if (Enemy[i].y < Hight_map){Enemy[i].y += enemy_sleep;}}}}}
}

7. 小球之间的吞噬关系

玩家小球与ai小球、ai小球与ai小球:

当两小球的圆心小于最大的那个圆的半径时,小的那个球就会被吃掉。吃点就是那个小球重新找个位置生成。吃完后,吃的那个小球半径增加被吃小球半径的十分之一。

ai小球与食物小球、玩家小球与食物小球:同上。

void EatFood()
{for (int i = 0; i < Food_num; i++){//玩家吃食物if (Distance(player.x, player.y, Food[i].x, Food[i].y) < player.r){player.r += Food[i].r / 100;Food[i].x = rand() % Wide_map;Food[i].y = rand() % Hight_map;Food[i].r = rand() % 5 + 1;Food[i].color = RGB(rand() % 256, rand() % 256, rand() % 256);}}for (int j = 0; j < Enemy_num; j++){//敌人吃食物for (int i = 0; i < Food_num; i++){if (Distance(Enemy[j].x, Enemy[j].y, Food[i].x, Food[i].y) < Enemy[j].r){Enemy[j].r += Food[i].r / 50;Food[i].x = rand() % Wide_map;Food[i].y = rand() % Hight_map;Food[i].r = rand() % 5 + 1;Food[i].color = RGB(rand() % 256, rand() % 256, rand() % 256);}}//敌人吃敌人for (int i = 0; i < Enemy_num; i++){if (Distance(Enemy[j].x, Enemy[j].y, Enemy[i].x, Enemy[i].y) < Enemy[j].r&& Enemy[j].r > Enemy[i].r){Enemy[j].r += Enemy[i].r / 10;Enemy[i].x = rand() % Wide_map;Enemy[i].y = rand() % Hight_map;Enemy[i].r = 10;Enemy[i].color = RGB(0, 255, 0);}if (Distance(Enemy[j].x, Enemy[j].y, Enemy[i].x, Enemy[i].y) < Enemy[i].r && Enemy[j].r < Enemy[i].r){Enemy[i].r += Enemy[j].r / 10;Enemy[j].x = rand() % Wide_map;Enemy[j].y = rand() % Hight_map;Enemy[j].r = 10;Enemy[j].color = RGB(0, 255, 0);}}if (Distance(player.x, player.y, Enemy[j].x, Enemy[j].y) < player.r){//玩家吃敌人if (player.r > Enemy[j].r){player.r += Enemy[j].r / 10;Enemy[j].x = rand() % Wide_map;Enemy[j].y = rand() % Hight_map;Enemy[j].r = 10;Enemy[j].color = RGB(0, 255, 0);}//敌人吃玩家else{if (invincibility == 0){Enemy[j].r += player.r / 10;player.x = Wide / 2;player.y = Hight / 2;player.r = 10;invincibility = 10;}}}}
}

最终效果:

球球大作战

源码:

#include<stdio.h>
#include<easyx.h>
#include<time.h>
#include<math.h>
#define Wide 1024
#define Hight 640
#define Wide_map (Wide*5)
#define Hight_map (Hight*5)
#define Food_num 1888
#define Enemy_num 888
//整个游戏地图
IMAGE map(Wide_map, Hight_map);
//复活时的无敌时间
int invincibility = 10; 
//玩家速度
int player_sleep = 5;
int l = 5;
int enemy_sleep = 5;
struct Ball
{int x;int y;float r;DWORD color;
};
struct Ball player;
struct Ball Food[Food_num];
struct Ball Enemy[Enemy_num];
//初始化球的数据
void Inset()
{srand((unsigned)time(NULL));player.x = Wide / 2;player.y = Hight / 2;player.r = 10;for (int i = 0; i < Food_num; i++){Food[i].x = rand() % Wide_map;Food[i].y = rand() % Hight_map;Food[i].r = rand() % 5 + 1;Food[i].color = RGB(rand() % 256, rand() % 256, rand() % 256);}for (int i = 0; i < Enemy_num; i++){Enemy[i].x = rand() % Wide_map;Enemy[i].y = rand() % Hight_map;Enemy[i].r = 10;Enemy[i].color = RGB(0,255,0);}}
//玩家操作
void Player_move()
{if (GetAsyncKeyState(VK_UP)){if (player.y > 0){player.y -= player_sleep;}}if (GetAsyncKeyState(VK_DOWN)){if (player.y < Hight_map)player.y += player_sleep;}if (GetAsyncKeyState(VK_LEFT)){if (player.x > 0)player.x -= player_sleep;}if (GetAsyncKeyState(VK_RIGHT)){if (player.x < Wide_map)player.x += player_sleep;}if (GetAsyncKeyState(0x20)){player_sleep = l + 5;}else{player_sleep = l;}
}
//距离
int Distance(int x, int y, int x1, int y1)
{return sqrt((x - x1) * (x - x1) + (y - y1) * (y - y1));
}
//敌人移动
void Enemy_move()
{srand((unsigned)time(NULL));for (int i = 0; i < Enemy_num; i++){int direction = rand() % 400;if (Distance(player.x, player.y, Enemy[i].x, Enemy[i].y) > player.r + Enemy[i].r + 50){if (direction < 100){if (Enemy[i].y > 0){Enemy[i].y -= enemy_sleep;}}if (direction < 200 && direction >= 100){if (Enemy[i].y < Hight_map)Enemy[i].y += enemy_sleep;}if (direction < 300 && direction >= 200){if (Enemy[i].x > 0)Enemy[i].x -= enemy_sleep;}if (direction <400 && direction >= 300){if (Enemy[i].x < Wide_map)Enemy[i].x += enemy_sleep;}}//敌人追击玩家if (Distance(player.x, player.y, Enemy[i].x, Enemy[i].y) < player.r + Enemy[i].r + 50){if (Enemy[i].r > player.r){if (Enemy[i].x < player.x){if (Enemy[i].x < Wide_map){Enemy[i].x += enemy_sleep;}}if (Enemy[i].x > player.x){if (Enemy[i].x > 0){Enemy[i].x -= enemy_sleep;}}if (Enemy[i].y < player.y){if (Enemy[i].y < Hight_map){Enemy[i].y += enemy_sleep;}}if (Enemy[i].y > player.y){if (Enemy[i].y > 0){Enemy[i].y -= enemy_sleep;}}}//敌人逃跑else{if (Enemy[i].x < player.x){if (Enemy[i].x > 0){Enemy[i].x -= enemy_sleep;}}if (Enemy[i].x > player.x){if (Enemy[i].x < Wide_map){Enemy[i].x += enemy_sleep;}}if (Enemy[i].y < player.y){if (Enemy[i].y > 0){Enemy[i].y -= enemy_sleep;}}if (Enemy[i].y > player.y){if (Enemy[i].y < Hight_map){Enemy[i].y += enemy_sleep;}}}}//for (int j = 0; j < Enemy_num; j++)//{//	if (Distance(Enemy[j].x, Enemy[j].y, Enemy[i].x, Enemy[i].y) < Enemy[j].r + Enemy[i].r + 30)//	{//		//敌人追敌人//		if (Enemy[i].r > Enemy[j].r)//		{//			int sleep = rand() % 6;//			int enemy_sleep1;//			if (sleep > 2)//			{//				enemy_sleep1 = enemy_sleep;//			}//			else//			{//				enemy_sleep1 = enemy_sleep + 5;//			}//			if (Enemy[i].x < Enemy[j].x)//			{//				if (Enemy[i].x < Wide_map)//				{//					Enemy[i].x += enemy_sleep1;//				}//			}//			if (Enemy[i].x > Enemy[j].x)//			{//				if (Enemy[i].x > 0)//				{//					Enemy[i].x -= enemy_sleep1;//				}//			}//			if (Enemy[i].y < Enemy[j].y)//			{//				if (Enemy[i].y < Hight_map)//				{//					Enemy[i].y += enemy_sleep1;//				}//			}//			if (Enemy[i].y > Enemy[j].y)//			{//				if (Enemy[i].y > 0)//				{//					Enemy[i].y -= enemy_sleep1;//				}//			}//		}//		//逃跑//		else//		{//			int sleep = rand() % 6;//			int enemy_sleep1;//			if (sleep > 2)//			{//				enemy_sleep1 = enemy_sleep;//			}//			else//			{//				enemy_sleep1 = enemy_sleep + 5;//			}//			if (Enemy[i].x < Enemy[j].x)//			{//				if (Enemy[i].x > 0)//				{//					Enemy[i].x -= enemy_sleep1;//				}//			}//			if (Enemy[i].x > Enemy[j].x)//			{//				if (Enemy[i].x < Wide_map)//				{//					Enemy[i].x += enemy_sleep1;//				}//			}//			if (Enemy[i].y < Enemy[j].y)//			{//				if (Enemy[i].y > 0)//				{//					Enemy[i].y -= enemy_sleep1;//				}//			}//			if (Enemy[i].y > Enemy[j].y)//			{//				if (Enemy[i].y < Hight_map)//				{//					Enemy[i].y += enemy_sleep1;//				}//			}//		}//	}//}}
}//吃食物
void EatFood()
{for (int i = 0; i < Food_num; i++){//玩家吃食物if (Distance(player.x, player.y, Food[i].x, Food[i].y) < player.r){player.r += Food[i].r / 100;Food[i].x = rand() % Wide_map;Food[i].y = rand() % Hight_map;Food[i].r = rand() % 5 + 1;Food[i].color = RGB(rand() % 256, rand() % 256, rand() % 256);}}for (int j = 0; j < Enemy_num; j++){//敌人吃食物for (int i = 0; i < Food_num; i++){if (Distance(Enemy[j].x, Enemy[j].y, Food[i].x, Food[i].y) < Enemy[j].r){Enemy[j].r += Food[i].r / 50;Food[i].x = rand() % Wide_map;Food[i].y = rand() % Hight_map;Food[i].r = rand() % 5 + 1;Food[i].color = RGB(rand() % 256, rand() % 256, rand() % 256);}}//敌人吃敌人for (int i = 0; i < Enemy_num; i++){if (Distance(Enemy[j].x, Enemy[j].y, Enemy[i].x, Enemy[i].y) < Enemy[j].r&& Enemy[j].r > Enemy[i].r){Enemy[j].r += Enemy[i].r / 10;Enemy[i].x = rand() % Wide_map;Enemy[i].y = rand() % Hight_map;Enemy[i].r = 10;Enemy[i].color = RGB(0, 255, 0);}if (Distance(Enemy[j].x, Enemy[j].y, Enemy[i].x, Enemy[i].y) < Enemy[i].r && Enemy[j].r < Enemy[i].r){Enemy[i].r += Enemy[j].r / 10;Enemy[j].x = rand() % Wide_map;Enemy[j].y = rand() % Hight_map;Enemy[j].r = 10;Enemy[j].color = RGB(0, 255, 0);}}if (Distance(player.x, player.y, Enemy[j].x, Enemy[j].y) < player.r){//玩家吃敌人if (player.r > Enemy[j].r){player.r += Enemy[j].r / 10;Enemy[j].x = rand() % Wide_map;Enemy[j].y = rand() % Hight_map;Enemy[j].r = 10;Enemy[j].color = RGB(0, 255, 0);}//敌人吃玩家else{if (invincibility == 0){Enemy[j].r += player.r / 10;player.x = Wide / 2;player.y = Hight / 2;player.r = 10;invincibility = 10;}}}}
}
//显示
void Show()
{//设置地图SetWorkingImage(&map);//清屏cleardevice();//背景颜色setbkcolor(WHITE);//划线颜色setlinecolor(RGB(230,231,239));//划线for (int i = 0; i < Wide_map; i += 10){line(i, 0, i, Hight_map);}for (int i = 0; i < Hight_map; i += 10){line(0, i, Wide_map, i);}//食物for (int i = 0; i < Food_num; i++){setfillcolor(Food[i].color);solidcircle(Food[i].x, Food[i].y, Food[i].r);}//敌人for (int i = 0; i < Enemy_num; i++){setfillcolor(Enemy[i].color);solidcircle(Enemy[i].x, Enemy[i].y, Enemy[i].r);}//玩家setfillcolor(RED);solidcircle(player.x, player.y, player.r);SetWorkingImage();int x = player.x - (Wide / 2);int y = player.y - (Hight / 2);//防止窗口越界if (x < 0){x = 0;}if (y < 0){y = 0;}if (x > Wide_map - Wide){x = Wide_map - Wide;}if (y > Hight_map - Hight){y = Hight_map - Hight;}//把map输出到窗口上putimage(0, 0, Wide, Hight, &map, x, y);
}
int main()
{initgraph(Wide, Hight);Inset();//缓冲BeginBatchDraw();while (1){if (invincibility > 0)invincibility--;Show();//玩家操作Player_move();Enemy_move();EatFood();//刷新FlushBatchDraw();}closegraph();return 0;
}

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

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

相关文章

基于FPGA的图像锐化算法(USM)设计

免费获取源码请关注微信号《FPGA学习笔记册》&#xff01; 1.图像锐化算法说明 图像锐化算法在实际的图像处理应用很广泛&#xff0c;例如&#xff1a;医学成像、工业检测和军事领域等&#xff1b;它的作用就是将模糊的图像变的更加清晰。常用的图像锐化算法有拉普拉斯算子、s…

算法--每日一练

1.数字A除本身以外的因数之和为数字B&#xff0c;B除本身之外的因数之和为A&#xff0c;这样的数对称为相亲数&#xff0c;例如&#xff1a;220的真因数之和为1245101120224455110284&#xff0c;284的真因数之和为 12471142220&#xff0c;请找出2到10000之间所有的相亲数。 …

C#面:简单介绍枚举

枚举&#xff08;Enumeration&#xff09; 枚举类型 是由基础整型数值类型的一组命名常量定义的值类型。&#xff08;这个拗口的表述来自官方文档&#xff09; 翻译成人话&#xff1a; 枚举是值类型。枚举的成员是常量默认情况下&#xff0c;枚举成员的关联常数值为类型 int…

linux上MySQL的安装

(1)解压安装包 tar -xzvf mysql-5.7.33-linux-glibc2.12-x86_64.tar.gz mv mysql-5.7.33-linux-glibc2.12-x86_64 /usr/local/mysql(2)创建数据目录 [roothecs-161929 3306]# mkdir -p /data/mysql/3306/data [roothecs-161929 3306]# mkdir -p /data/mysql/3306/binlog [roo…

react框架中无构建模式直接使用es6组件

react框架&#xff0c;看到的总是使用es5&#xff0c;通过webpack编译构建。react官方&#xff0c;直到现在的v18.1.0版本中&#xff0c;只有cjs和umd版本&#xff0c;都没有esm&#xff08;es6&#xff09;版本&#xff0c;看起来是对es6的不认可&#xff1f; 但是&#xff0…

科研学习|论文解读——一种修正评分偏差并精细聚类中心的协同过滤推荐算法

知网链接 一种修正评分偏差并精细聚类中心的协同过滤推荐算法 - 中国知网 (cnki.net) 摘要 协同过滤作为国内外学者普遍关注的推荐算法之一&#xff0c;受评分失真和数据稀疏等问题影响&#xff0c;算法推荐效果不尽如人意。为解决上述问题&#xff0c;本文提出了一种改进的聚类…

centos 7.x 上安装 AI insightface + pytorch + cuda

centos 英伟达检查工具 lsb_release -a nvidia-smi lspci | grep -i nvidia CUDA v11.7 安装 首先在centos机器上必须先安装英伟达驱动&#xff0c;参考下面的文档 https://docs.nvidia.com/cuda/cuda-installation-guide-linux/index.html# https://developer.nvidia.com/c…

Docker单机下的容器网络管理

Docker容器网络管理 容器网络类型 Docker安装以后&#xff0c;会在我们的主机上创建三个网络 docker network ls可以看到有bridge、host和none三种网络类型 我们先把ubuntu的网络环境配置一下 docker run -it ubuntu apt update apt install net-tools iputils-ping curl这…

HTML静态网页成品作业(HTML+CSS)——家乡广州介绍设计制作(5个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有5个页面。 二、作品演示 三、代…

Android Bundle putBinder传输超过1MB数据,Kotlin

Android Bundle putBinder传输超过1MB数据&#xff0c;Kotlin 由于Android系统架构的设计&#xff0c;Activity/Fragment之间通过Intent在Bundle塞进数据进行传输时候&#xff0c;如果数据超过1MB&#xff0c;会抛JE&#xff1a; java.lang.RuntimeException: android.os.Tran…

浏览器预览word

浏览器打开word是直接下载&#xff0c;而打开pdf才是预览。所以需要先将word转为pdf&#xff0c;visual basic将word转pdf的代码&#xff1a; Sub word2pdf()ActiveDocument.ExportAsFixedFormat OutputFileName:"C:\Users\zhour\Documents\contact.pdf", ExportFor…

proto的singular解释

在计算机科学和特别是在协议缓冲区&#xff08;Protocol Buffers&#xff0c;简称Proto&#xff09;的上下文中&#xff0c;“singular”这个词具有特定的含义。Protocol Buffers是Google开发的一种语言中立、平台中立、可扩展的序列化结构数据的方法&#xff0c;广泛用于通信协…

大型语言模型RAG(检索增强生成):检索技术的应用与挑战

摘要 检索增强生成&#xff08;RAG&#xff09;系统通过结合传统的语言模型生成能力和结构化数据检索&#xff0c;为复杂的问题提供精确的答案。本文深入探讨了RAG系统中检索技术的工作原理、实现方式以及面临的挑战&#xff0c;并对未来的发展方向提出了展望。 随着大型预训…

IDEA中配置完Maven后 重启就恢复默认设置

目录 问题描述解决方案-修改other settingsother settings改完也不奏效参考这里 问题描述 在IDEA的settings里配置完Maven之后 每次重启或新建一个项目/窗口之后 又恢复成之前的默认配置 解决方案-修改other settings 这和IDEA的版本有关 目前我使用的版本(2020.3.4) 配置完重…

自监督学习的新前沿:大型模型在自然语言处理中的应用

摘要&#xff1a; 自监督学习的新前沿&#xff0c;特别是大型模型在自然语言处理中的应用&#xff0c;正在引领自然语言处理领域的发展。本文将概述自监督学习的新前沿&#xff0c;特别是大型模型在自然语言处理中的应用&#xff0c;以及其在自然语言处理领域的重要性和应用前…

计算机网络期末98+冲刺笔记

一、计算机网络基础 1.1计算机网络的概述 计算机网络的定义&#xff1a;利用通信设备和线路&#xff0c;将地理位置不同的具有独立功能的多台计算机机器外部设备连接起来&#xff0c;在网络操作系统、网络管理软件及网络通信协议的管理和协调下&#xff0c;实现资源共享和信息…

cpp qt 一个奇怪的bug

今天在用cpp qt的时候发现了一个奇怪的东西 这是我的源代码 #include "mywidget.h" #include <QPushButton>myWidget::myWidget(QWidget *parent): QWidget(parent) {QPushButton * btn1 new QPushButton;btn1->show();btn1->setParent(this);btn1-&g…

如何恢复丢失未保存的 Word 文档指南

在广阔的数字领域&#xff0c;对丢失未保存的 Word 文档的恐惧对于用户来说是再熟悉不过的焦虑了。本指南旨在对用户可能发现自己迫切需要恢复未保存文档的各种场景进行详尽的探索。无论是由于保存失败、意外的系统崩溃还是令人心碎的意外删除&#xff0c;请放心&#xff0c;我…

无线业务配置建议

WPA2802.1X的接入方式 对于商用环境应该提供更安全的认证和加密方式&#xff0c; 推荐使用WPA2的AES加密方式&#xff0c;结合安全级别较高的802.1X认证方式&#xff0c;更适合封闭性较高的企业级用户。 # 配置WPA2的AES 802.1X认证方式。 <HUAWEI> system-view [HUAW…

Docker Commit提交

Docker Commit提交 Docker Commit镜像提交 以一个正在运行的tomcat为例因为docker拉取的镜像都是删减版&#xff0c;所以需要将webapp.dist的文件内容复制到webapps中再将自己制作的镜像放在正在运行服务器上&#xff0c;不是云端服务器上 #进入tomcat&#xff0c;这是一个正…