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

基于链表实现贪吃蛇游戏

本文中,我们将使用链表和一些Win32 API的知识来实现贪吃蛇小游戏

一、功能

(1)游戏载入界面

(2)地图的绘制

(3)蛇身的移动和变长

(4)食物的生成

(5)死亡判定

(6)计算得分

(7)退出游戏和暂停游戏

实现贪吃蛇小游戏,我们需要创建3个文件来实现不同的部分

  • Snake.c:游戏函数的实现
  • Snake.h:结构体定义、头文件引用、宏定义和函数声明
  • test.c:主函数的实现

二、Snake.h 

#pragma once
#include <stdio.h>
#include <stdlib.h>
#include <Windows.h>
#include <stdbool.h>
#include <locale.h>#define KEY_PRESS(VK) ((GetAsyncKeyState(VK) & 0x1) ? 1 : 0)#define WALL L'□'
#define BODY L'●'
#define FOOD L'★'//蛇的初始位置
#define POS_X 24
#define POS_Y 5enum GAME_STATUS
{RUN,ESC,KILL_BY_WALL,KILL_BY_SELF,
};enum DIRECTION
{UP,DOWN,LEFT,RIGHT,
};//蛇⾝节点
typedef struct SnakeNode
{short x;short y;struct SnakeNode* next;
}SnakeNode;typedef struct Snake
{SnakeNode* pSnake;//指向蛇头SnakeNode* Food; int SleepTime;int Score;int FoodScore;enum GAME_STATUS Status;enum DIRECTION Dir;
}Snake;void GameStart(Snake* ps);void GameRun(Snake* ps);void GameEnd(Snake* ps);void SetPos(short x, short y);//设置光标坐标void WelcomeToGame();//欢迎界面void CreateMap();//创建地图void InitSnake(Snake* ps);//初始化蛇void CreateFood(Snake* ps);//生成食物void PrintHelpInfo();//打印教程void SnakeMove(Snake* ps);//蛇身移动void EatFood(Snake* ps, SnakeNode* next);//移动后吃到食物void NotEatFood(Snake* ps, SnakeNode* next);//移动后没吃到食物void KillByWall(Snake* ps);//检测是否撞墙void KillBySelf(Snake* ps);//检测是否撞到自己

三、Snake.c

在Snake.c中,我们将整个游戏拆分成游戏前的准备、游戏运行中和游戏结束后三部分

首先要在头文件中定义蛇的节点等相关信息

enum GAME_STATUS //游戏状态的枚举
{RUN, //游戏正常运行中ESC, //正常退出游戏KILL_BY_WALL, //撞到墙导致游戏结束KILL_BY_SELF, //撞到自己导致游戏结束
};enum DIRECTION //蛇身方向的枚举
{UP,DOWN,LEFT,RIGHT,
};//蛇⾝节点
typedef struct SnakeNode
{short x; //x轴坐标short y; //y轴坐标struct SnakeNode* next;
}SnakeNode;typedef struct Snake
{SnakeNode* pSnake; //指向蛇头SnakeNode* Food;  //指向食物int SleepTime; //蛇身运动的速度int Score; //总分数int FoodScore; //每个食物的分数enum GAME_STATUS Status; //游戏运行的状态enum DIRECTION Dir; //蛇身方向
}Snake;

接下来就可以开始设计游戏前的准备程序了

2.1 游戏前的准备

为了美观,我们可以使用一些cmd命令来设置控制台窗口的长宽等信息

控制台窗口实际上是有坐标的,也就是有行和列的

最左上角的位置的坐标为(0,0),像这样的一个字符高为1 宽为1

所以我们可以通过cmd命令将控制台设置为30行,100列,并将标题改成贪吃蛇

void GameStart(Snake* ps)
{system("mode con cols=100 lines=30");system("title 贪吃蛇");HANDLE handle = GetStdHandle(STD_OUTPUT_HANDLE);//获得设备句柄CONSOLE_CURSOR_INFO CursorInfo;GetConsoleCursorInfo(handle, &CursorInfo);      //获得光标信息CursorInfo.bVisible = false;                    //设置光标为不可见SetConsoleCursorInfo(handle, &CursorInfo);      //保存光标信息//欢迎界面WelcomeToGame();//创建地图CreateMap();//初始化蛇InitSnake(ps);//生成食物CreateFood(ps);
}

将剩下的四个功能分别分装在四个函数中

(1)欢迎界面

void WelcomeToGame()//欢迎界面
{SetPos(45, 10);printf("欢迎来到贪吃蛇小游戏");SetPos(45, 15);system("pause");system("cls");SetPos(35, 10);printf("用 ↑.↓.←.→ 控制蛇的行动,F3为加速,F4为减速");SetPos(35, 11);printf("加速能得到更多的分数");SetPos(45, 15);system("pause");system("cls");
}

其中,SetPos函数是用来设置光标坐标的,因为在控制台中printf中的内容会从光标的位置开始打印。

void SetPos(short x, short y) // 设置光标坐标
{COORD pos = {x, y};HANDLE handle = GetStdHandle(STD_OUTPUT_HANDLE);SetConsoleCursorPosition(handle, pos);
}

完成后的效果如下:

(2)创建地图

创建地图时需要用到宽字符的打印,宽字符也就是高为1 宽为2的字符,需要用wprintf函数打印

void CreateMap() // 创建地图
{SetPos(0, 0);int i = 0;for (i = 0; i < 58; i += 2){SetPos(i, 0);wprintf(L"%lc", L'□');}for (i = 0; i < 58; i += 2){SetPos(i, 26);wprintf(L"%lc", L'□');}for (i = 1; i < 26; i++){SetPos(0, i);wprintf(L"%lc", L'□');}for (i = 1; i < 26; i++){SetPos(56, i);wprintf(L"%lc", L'□');}
}

我们也可以用宏定义将 L'□' 替换

#define WALL L'□'

(3)初始化蛇

void InitSnake(Snake *ps) // 初始化蛇
{SnakeNode *cur = ps->pSnake = NULL;for (int i = 0; i < 5; i++){cur = (SnakeNode *)malloc(sizeof(SnakeNode));if (cur == NULL){perror("InitSnake:malloc fail");return;}cur->next = NULL;cur->x = POS_X + i * 2;cur->y = POS_Y;if (ps->pSnake == NULL)ps->pSnake = cur;else{cur->next = ps->pSnake;ps->pSnake = cur;}}while (cur){SetPos(cur->x, cur->y);wprintf(L"%lc", BODY);cur = cur->next;}ps->Food = NULL;ps->SleepTime = 200;ps->Score = 0;ps->FoodScore = 10;ps->Status = RUN;ps->Dir = RIGHT;
}

这里的蛇身和蛇的初始位置也用了宏定义

#define BODY L'●'
//蛇的初始位置
#define POS_X 24
#define POS_Y 5

 (4)生成食物

void CreateFood(Snake *ps) // 生成食物
{int x = 0;int y = 0;SnakeNode *cur = ps->pSnake;
again:do{x = rand() % 53 + 2;y = rand() % 25 + 1;} while (x % 2 == 1);while (cur){if (cur->x == x || cur->y == y){goto again;break;}cur = cur->next;}ps->Food = (SnakeNode *)malloc(sizeof(SnakeNode));if (ps->Food == NULL){perror("CreateFood:malloc fail");return;}ps->Food->x = x;ps->Food->y = y;SetPos(x, y);wprintf(L"%lc", FOOD);
}

这里的食物也用了宏定义

#define FOOD L'★'

2.2 游戏运行中

这一部分需要包含分数等信息的打印和按键输入的判定等功能

这里将按键输入的判断封装为了宏

#define KEY_PRESS(VK) ((GetAsyncKeyState(VK) & 0x1) ? 1 : 0)

GetAsyncKeyState的返回值是short类型,在上一次调用完该函数后,如果返回的16位的short数据中最高位是1,说明按键的状态为按下,最高位是0则为抬起 

void GameRun(Snake* ps)
{PrintHelpInfo();//打印教程do{//打印信息SetPos(60, 10);printf("当前得分:%2d", ps->Score);SetPos(60, 11);printf("当前速度:%3d", (400 - ps->SleepTime) / 40);SetPos(60, 12);printf("每个食物得分:%2d", ps->FoodScore);//判断按键if (KEY_PRESS(VK_UP) && ps->Dir != DOWN){ps->Dir = UP;}if (KEY_PRESS(VK_DOWN) && ps->Dir != UP){ps->Dir = DOWN;}if (KEY_PRESS(VK_LEFT) && ps->Dir != RIGHT){ps->Dir = LEFT;}if (KEY_PRESS(VK_RIGHT) && ps->Dir != LEFT){ps->Dir = RIGHT;}if (KEY_PRESS(VK_ESCAPE)){ps->Status = ESC;break;}if (KEY_PRESS(VK_SPACE)){pause();}if (KEY_PRESS(VK_F3)){if (ps->SleepTime > 40){ps->SleepTime -= 40;ps->FoodScore += 2;}}if (KEY_PRESS(VK_F4)){if (ps->FoodScore > 2){ps->SleepTime += 40;ps->FoodScore -= 2;}}Sleep(ps->SleepTime);//蛇身移动SnakeMove(ps);} while (ps->Status == RUN);
}

(1)打印教程

void PrintHelpInfo() // 打印教程
{SetPos(60, 16);printf("请按空格键开始游戏");SetPos(60, 17);printf("不能撞到墙上或者撞到自己");SetPos(60, 18);printf("用 ↑.↓.←.→ 控制蛇的行动");SetPos(60, 19);printf("F3为加速,F4为减速");SetPos(60, 20);printf("ESC:退出游戏  space:暂停游戏");
}

效果如下

(2)暂停游戏

void pause() // 暂停游戏
{while (1){Sleep(200);if (KEY_PRESS(VK_SPACE)){break;}}
}

(3)蛇身移动

void SnakeMove(Snake *ps) // 蛇身移动
{SnakeNode *next = (SnakeNode *)malloc(sizeof(SnakeNode));if (next == NULL){perror("SnakeMove:malloc fail");return;}switch (ps->Dir){case UP:next->x = ps->pSnake->x;next->y = ps->pSnake->y - 1;break;case DOWN:next->x = ps->pSnake->x;next->y = ps->pSnake->y + 1;break;case LEFT:next->x = ps->pSnake->x - 2;next->y = ps->pSnake->y;break;case RIGHT:next->x = ps->pSnake->x + 2;next->y = ps->pSnake->y;break;}if (next->x == ps->Food->x && next->y == ps->Food->y)EatFood(ps, next);elseNotEatFood(ps, next);KillByWall(ps);KillBySelf(ps);
}

(4)移动后吃到食物的情况

void EatFood(Snake *ps, SnakeNode *next) // 移动后吃到食物
{next->next = ps->pSnake;ps->pSnake = next;SetPos(next->x, next->y);wprintf(L"%lc", BODY);ps->Score += ps->FoodScore;free(ps->Food);ps->Food = NULL;CreateFood(ps);
}

(5)移动后没吃到食物的情况

void NotEatFood(Snake *ps, SnakeNode *next) // 移动后没吃到食物
{next->next = ps->pSnake;ps->pSnake = next;SnakeNode *cur = ps->pSnake;while (cur->next->next){SetPos(cur->x, cur->y);wprintf(L"%lc", BODY);cur = cur->next;}SetPos(cur->next->x, cur->next->y);printf("  ");free(cur->next);cur->next = NULL; // 不置空会出现问题
}

(6)检测是否撞墙

void KillByWall(Snake *ps) // 检测是否撞墙
{if (ps->pSnake->x == 0 ||ps->pSnake->x == 56 ||ps->pSnake->y == 0 ||ps->pSnake->y == 25){ps->Status = KILL_BY_WALL;}
}

(7)检测是否撞到自己

void KillBySelf(Snake *ps) // 检测是否撞到自己
{SnakeNode *cur = ps->pSnake->next;while (cur){if (ps->pSnake->x == cur->x && ps->pSnake->y == cur->y){ps->Status = KILL_BY_SELF;}cur = cur->next;}
}

2.3 游戏结束后

void GameEnd(Snake *ps)
{SetPos(24, 12);switch (ps->Status){case KILL_BY_SELF:printf("你撞到了自己");break;case KILL_BY_WALL:printf("你撞到墙了");break;case ESC:printf("游戏退出中...");break;}SnakeNode *cur = ps->pSnake;while (ps->pSnake){ps->pSnake = ps->pSnake->next;free(cur);cur = ps->pSnake;}
}

2.4 完整代码

#include "snake.h"void SetPos(short x, short y)//设置光标坐标
{COORD pos = { x,y };HANDLE handle = GetStdHandle(STD_OUTPUT_HANDLE);SetConsoleCursorPosition(handle, pos);
}void WelcomeToGame()//欢迎界面
{SetPos(45, 10);printf("欢迎来到贪吃蛇小游戏");SetPos(45, 15);system("pause");system("cls");SetPos(35, 10);printf("用 ↑.↓.←.→ 控制蛇的行动,F3为加速,F4为减速");SetPos(35, 11);printf("加速能得到更多的分数");SetPos(45, 15);system("pause");system("cls");
}void CreateMap()//创建地图
{SetPos(0, 0);int i = 0;for (i = 0; i < 58; i += 2){SetPos(i, 0);wprintf(L"%lc", WALL);}for (i = 0; i < 58; i += 2){SetPos(i, 26);wprintf(L"%lc", WALL);}for (i = 1; i < 26; i++){SetPos(0, i);wprintf(L"%lc", WALL);}for (i = 1; i < 26; i++){SetPos(56, i);wprintf(L"%lc", WALL);}
}void InitSnake(Snake* ps)//初始化蛇
{SnakeNode* cur = ps->pSnake = NULL;for (int i = 0; i < 5; i++){cur = (SnakeNode*)malloc(sizeof(SnakeNode));if (cur == NULL){perror("InitSnake:malloc fail");return;}cur->next = NULL;cur->x = POS_X + i * 2;cur->y = POS_Y;if (ps->pSnake == NULL)ps->pSnake = cur;else{cur->next = ps->pSnake;ps->pSnake = cur;}}while (cur){SetPos(cur->x, cur->y);wprintf(L"%lc", BODY);cur = cur->next;}ps->Food = NULL;ps->SleepTime = 200;ps->Score = 0;ps->FoodScore = 10;ps->Status = RUN;ps->Dir = RIGHT;
}void CreateFood(Snake* ps)//生成食物
{int x = 0;int y = 0;SnakeNode* cur = ps->pSnake;
again:do {x = rand() % 53 + 2;y = rand() % 25 + 1;} while (x % 2 == 1);while (cur){if (cur->x == x || cur->y == y){goto again;break;}cur = cur->next;}ps->Food = (SnakeNode*)malloc(sizeof(SnakeNode));if (ps->Food == NULL){perror("CreateFood:malloc fail");return;}ps->Food->x = x;ps->Food->y = y;SetPos(x, y);wprintf(L"%lc", FOOD);
}void GameStart(Snake* ps)
{system("mode con cols=100 lines=30");system("title 贪吃蛇");HANDLE handle = GetStdHandle(STD_OUTPUT_HANDLE);CONSOLE_CURSOR_INFO CursorInfo;GetConsoleCursorInfo(handle, &CursorInfo);CursorInfo.bVisible = false;SetConsoleCursorInfo(handle, &CursorInfo);WelcomeToGame();CreateMap();InitSnake(ps);CreateFood(ps);
}void PrintHelpInfo()//打印教程
{SetPos(60, 16);printf("请按空格键开始游戏");SetPos(60, 17);printf("不能撞到墙上或者撞到自己");SetPos(60, 18);printf("用 ↑.↓.←.→ 控制蛇的行动");SetPos(60, 19);printf("F3为加速,F4为减速");SetPos(60, 20);printf("ESC:退出游戏  space:暂停游戏");
}void pause()//暂停游戏
{while (1){Sleep(200);if (KEY_PRESS(VK_SPACE)){break;}}
}void EatFood(Snake* ps, SnakeNode* next)//移动后正好吃到食物
{next->next = ps->pSnake;ps->pSnake = next;SetPos(next->x, next->y);wprintf(L"%lc", BODY);ps->Score += ps->FoodScore;free(ps->Food);ps->Food = NULL;CreateFood(ps);
}void NotEatFood(Snake* ps, SnakeNode* next)//移动后没吃到食物
{next->next = ps->pSnake;ps->pSnake = next;SnakeNode* cur = ps->pSnake;while (cur->next->next){SetPos(cur->x, cur->y);wprintf(L"%lc", BODY);cur = cur->next;}SetPos(cur->next->x, cur->next->y);printf("  ");free(cur->next);cur->next = NULL;//亲测不置空会出现问题
}void KillByWall(Snake* ps)//检测是否撞墙
{if (ps->pSnake->x == 0 ||ps->pSnake->x == 56 ||ps->pSnake->y == 0 ||ps->pSnake->y == 25){ps->Status = KILL_BY_WALL;}
}void KillBySelf(Snake* ps)//检测是否撞到自己
{SnakeNode* cur = ps->pSnake->next;while (cur){if (ps->pSnake->x == cur->x && ps->pSnake->y == cur->y){ps->Status = KILL_BY_SELF;}cur = cur->next;}
}void SnakeMove(Snake* ps)//蛇身移动
{SnakeNode* next = (SnakeNode*)malloc(sizeof(SnakeNode));if (next == NULL){perror("SnakeMove:malloc fail");return;}switch (ps->Dir){case UP:next->x = ps->pSnake->x;next->y = ps->pSnake->y - 1;break;case DOWN:next->x = ps->pSnake->x;next->y = ps->pSnake->y + 1;break;case LEFT:next->x = ps->pSnake->x - 2;next->y = ps->pSnake->y;break;case RIGHT:next->x = ps->pSnake->x + 2;next->y = ps->pSnake->y;break;}if (next->x == ps->Food->x && next->y == ps->Food->y)EatFood(ps, next);elseNotEatFood(ps, next);KillByWall(ps);KillBySelf(ps);
}void GameRun(Snake* ps)
{PrintHelpInfo();do{//打印信息SetPos(60, 10);printf("当前得分:%2d", ps->Score);SetPos(60, 11);printf("当前速度:%3d", (400 - ps->SleepTime) / 40);SetPos(60, 12);printf("每个食物得分:%2d", ps->FoodScore);//判断按键if (KEY_PRESS(VK_UP) && ps->Dir != DOWN){ps->Dir = UP;}if (KEY_PRESS(VK_DOWN) && ps->Dir != UP){ps->Dir = DOWN;}if (KEY_PRESS(VK_LEFT) && ps->Dir != RIGHT){ps->Dir = LEFT;}if (KEY_PRESS(VK_RIGHT) && ps->Dir != LEFT){ps->Dir = RIGHT;}if (KEY_PRESS(VK_ESCAPE)){ps->Status = ESC;break;}if (KEY_PRESS(VK_SPACE)){pause();}if (KEY_PRESS(VK_F3)){if (ps->SleepTime > 40){ps->SleepTime -= 40;ps->FoodScore += 2;}}if (KEY_PRESS(VK_F4)){if (ps->FoodScore > 2){ps->SleepTime += 40;ps->FoodScore -= 2;}}Sleep(ps->SleepTime);//蛇身移动SnakeMove(ps);} while (ps->Status == RUN);
}void GameEnd(Snake* ps)
{SetPos(24, 12);switch (ps->Status){case KILL_BY_SELF:printf("你撞到了自己");break;case KILL_BY_WALL:printf("你撞到墙了");break;case ESC:printf("游戏退出中...");break;}SnakeNode* cur = ps->pSnake;while (ps->pSnake){ps->pSnake = ps->pSnake->next;free(cur);cur = ps->pSnake;}
}

四、test.c

#include "snake.h"void Test()
{srand((unsigned int)time(NULL));char ch = 0;do{Snake snake;GameStart(&snake);GameRun(&snake);GameEnd(&snake);if (snake.Status == ESC)break;SetPos(24, 13);printf("再来一局吗?(Y/N):");scanf(" %c", &ch);} while (ch == 'Y' || ch == 'y');SetPos(0, 27);
}int main()
{setlocale(LC_ALL, "chs");Test();return 0;
}

相关文章:

基于链表实现贪吃蛇游戏

本文中&#xff0c;我们将使用链表和一些Win32 API的知识来实现贪吃蛇小游戏 一、功能 &#xff08;1&#xff09;游戏载入界面 &#xff08;2&#xff09;地图的绘制 &#xff08;3&#xff09;蛇身的移动和变长 &#xff08;4&#xff09;食物的生成 &#xff08;5&…...

Python网络爬虫实战——实验6:Python实现js逆向与加解密

【实验内容】 本实验主要介绍在数据采集过程中对js代码进行分析从而对加密字段进行解密。 【实验目的】 1、理解js逆向工程的概念 2、学会逆向工程中的加解密分析 【实验步骤】 步骤1 理解js逆向工程的概念 步骤2 学会逆向工程中的加解密分析 步骤3 采集广东政府采购网 步…...

【python】使用aiohttp库编写一个简单的异步服务器

1. aiohttp介绍 aiohttp 是一个用于编写异步 HTTP 客户端和服务器的 Python 库。它建立在 Python 的 asyncio 库之上&#xff0c;提供了一种方便的方式来处理异步请求和响应。 官网地址&#xff1a;Welcome to AIOHTTP — aiohttp 3.9.1 documentation 以下是 aiohttp 的一些…...

新手使用代理IP接入代码教程

“实现匿名访问与数据保护在当今互联网高速发展的时代&#xff0c;网络安全和隐私保护成为了越来越重要的议题。代理IP可以隐藏用户的真实IP地址&#xff0c;从而实现匿名访问。为了保护用户的隐私和数据安全&#xff0c;许多网站和应用程序都采用了代理IP技术。” 一、代理IP的…...

JVM问题排查手册

三万字长文&#xff1a;JVM内存问题排查Cookbook 一、Heap快照 # jmap命令保存整个Java堆&#xff08;在你dump的时间不是事故发生点的时候尤其推荐&#xff09; jmap -dump:formatb,fileheap.bin <pid> # jmap命令只保存Java堆中的存活对象, 包含live选项&#xff0c;…...

前端canvas项目实战——简历制作网站(三)——右侧属性栏(线条宽度样式)

目录 前言一、效果展示二、实现步骤1. 实现线条宽度&#xff08;strokeWidth&#xff09;的属性模块2. 实线线条样式&#xff08;strokeDashArray&#xff09;的属性模块3. 意料之外的“联动” 三、Show u the code后记 前言 上一篇博文中&#xff0c;我们初步实现了右侧属性栏…...

字节跳动二面经典题目

前言 语论即为「语兴式论语」&#xff0c;以语录体及对话的形式&#xff0c;沉淀球友实际工作学习中存在的疑难杂症解答&#xff0c;希望能够更好的帮助到球友和粉丝。欢迎关注公众号&#xff1a;语数 本期投稿 本期语数精选来源于球友应对字节跳动二面时候的场景问题 数仓工程…...

微搭低代码从入门到精通01应用介绍

目录 1 学习路线图2 应用介绍3 编辑器介绍总结 低代码的概念于2014年由 Forrester 首次正式提出。其将低代码定义为&#xff1a;能够以“最少的手写代码”和设置快速开发应用、配置和部署业务应用程序。 不同应用厂商的解法不一样&#xff0c;Gartner评估了400多款低代码/无代码…...

论文阅读《thanking frequency fordeepfake detection》

项目链接&#xff1a;https://github.com/yyk-wew/F3Net 这篇论文从频域的角度出发&#xff0c;提出了频域感知模型用于deepfake检测的模型 整体架构图&#xff1a; 1.FAD&#xff1a; 频域感知分解&#xff0c;其实就是利用DCT变换&#xff0c;将空间域转换为频域&#xff…...

ArcgisForJs快速入门

文章目录 0.引言1.前端代码编辑工具2.使用ArcgisForJs创建一个简单应用3.切片地图服务图层4.动态地图服务图层5.地图事件 0.引言 ArcGIS API for JavaScript是一款由Esri公司开发的用于创建WebGIS应用的JavaScript库。它允许开发者通过调用ArcGIS Server的REST API&#xff0c…...

【解决方法】git pull报错ssh: connect to host github.com port 22: Connection timed out

问题 git pull ssh: connect to host github.com port 22: Connection timed out fatal: Could not read from remote repository.解决方法 在C:\Users\username.ssh文件夹下新建config文件&#xff0c;填入以下文本&#xff08;如有则直接在文件最后一行新增&#xff09;&am…...

30天精通Nodejs--第三十天:项目实战-物联网应用

目录 引言架构设计编码创建项目数据服务模拟设备消息接收并保存设备数据后端接口项目启动及接口测试项目启动测试源码地址结语引言 在之前的一系列文章中,我们已系统性地探讨了诸多Node.js相关的技术要点与理论背景。随着知识体系的铺垫到位,我们现在步入了实战环节。接下来…...

java 社区资源管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 java Web社区资源管系统是一套完善的java web信息管理系统 &#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为Mysql5.…...

网络编程套接字(Socket)

为什么需要网络编程??? -丰富的网络资源 每天你在b站上刷着喜欢的up主的视频,实质是通过网络,获取到网络上的一个视频资源 与本地打开文件类似,只是视频文件这个资源来源是网络 所谓的网络编程,其实就是从网络上获取各种数据资源 什么是网络编程?? 网络编程,指的是网络…...

C语言第十一弹---函数(下)

​ ✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】 函数 1、嵌套调用和链式访问 1.1、嵌套调用 1.2、链式访问 2、函数的声明和定义 2.1、单个文件 2.2、多个文件 2.3、static 和 extern 2.3.1、static…...

Unity读书系列《Unity3D游戏开发》——拓展编辑器(一)

文章目录 前言一、扩展Project视图1、右键扩展菜单&#xff08;Asset&#xff09;2、监听事件3、拓展布局 二、扩展Hierarchy视图1、拓展菜单&#xff08;GameObject&#xff09;2、拓展布局3、重写菜单 三、扩展Inspector视图1、扩展原生组件2、扩展继承组件 四、扩展Scene视图…...

【Git】项目管理笔记

文章目录 本地电脑初始化docker报错.gitignoregit loggit resetgit statusgit ls-filesgit rm -r -f --cached拉取仓库文件更新本地的项目报错处理! [rejected] master -> master (fetch first)gitgitee.com: Permission denied (publickey).error: remote origin already e…...

中文词性标注工具pkuseg例子(运行结果,不太好)

pkuseg_demo.md pkuseg 预训练模型 预训练模型science 安装 pip3 install pkuseg cd /rot/pkuseg_home/model/wget https://github.com/lancopku/pkuseg-python/releases/download/v0.0.25/science.zip uzip science.zip -d ./science/ ls /rot/pkuseg_home/model/science/…...

获取URL参数:split方法、URLSearchParams方法示例

在JavaScript中&#xff0c;可以使用多种方法来获取URL参数&#xff0c;其中常用的方法有split()和URLSearchParams()。 使用split()方法获取URL参数&#xff1a; split()方法将字符串分割成数组。可以使用split()方法将URL分割成协议、主机、路径和查询字符串等部分。然后可…...

SparkSql---用户自定义函数UDFUDAF

文章目录 1.UDF2.UDAF2.1 UDF函数实现原理2.2需求:计算用户平均年龄2.2.1 使用RDD实现2.2.2 使用UDAF弱类型实现2.2.3 使用UDAF强类型实现 1.UDF 用户可以通过 spark.udf 功能添加自定义函数&#xff0c;实现自定义功能。 如&#xff1a;实现需求在用户name前加上"Name:…...

MPNet:旋转机械轻量化故障诊断模型详解python代码复现

目录 一、问题背景与挑战 二、MPNet核心架构 2.1 多分支特征融合模块(MBFM) 2.2 残差注意力金字塔模块(RAPM) 2.2.1 空间金字塔注意力(SPA) 2.2.2 金字塔残差块(PRBlock) 2.3 分类器设计 三、关键技术突破 3.1 多尺度特征融合 3.2 轻量化设计策略 3.3 抗噪声…...

Vue记事本应用实现教程

文章目录 1. 项目介绍2. 开发环境准备3. 设计应用界面4. 创建Vue实例和数据模型5. 实现记事本功能5.1 添加新记事项5.2 删除记事项5.3 清空所有记事 6. 添加样式7. 功能扩展&#xff1a;显示创建时间8. 功能扩展&#xff1a;记事项搜索9. 完整代码10. Vue知识点解析10.1 数据绑…...

深入剖析AI大模型:大模型时代的 Prompt 工程全解析

今天聊的内容&#xff0c;我认为是AI开发里面非常重要的内容。它在AI开发里无处不在&#xff0c;当你对 AI 助手说 "用李白的风格写一首关于人工智能的诗"&#xff0c;或者让翻译模型 "将这段合同翻译成商务日语" 时&#xff0c;输入的这句话就是 Prompt。…...

椭圆曲线密码学(ECC)

一、ECC算法概述 椭圆曲线密码学&#xff08;Elliptic Curve Cryptography&#xff09;是基于椭圆曲线数学理论的公钥密码系统&#xff0c;由Neal Koblitz和Victor Miller在1985年独立提出。相比RSA&#xff0c;ECC在相同安全强度下密钥更短&#xff08;256位ECC ≈ 3072位RSA…...

C++:std::is_convertible

C++标志库中提供is_convertible,可以测试一种类型是否可以转换为另一只类型: template <class From, class To> struct is_convertible; 使用举例: #include <iostream> #include <string>using namespace std;struct A { }; struct B : A { };int main…...

k8s从入门到放弃之Ingress七层负载

k8s从入门到放弃之Ingress七层负载 在Kubernetes&#xff08;简称K8s&#xff09;中&#xff0c;Ingress是一个API对象&#xff0c;它允许你定义如何从集群外部访问集群内部的服务。Ingress可以提供负载均衡、SSL终结和基于名称的虚拟主机等功能。通过Ingress&#xff0c;你可…...

大型活动交通拥堵治理的视觉算法应用

大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动&#xff08;如演唱会、马拉松赛事、高考中考等&#xff09;期间&#xff0c;城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例&#xff0c;暖城商圈曾因观众集中离场导致周边…...

LLM基础1_语言模型如何处理文本

基于GitHub项目&#xff1a;https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken&#xff1a;OpenAI开发的专业"分词器" torch&#xff1a;Facebook开发的强力计算引擎&#xff0c;相当于超级计算器 理解词嵌入&#xff1a;给词语画"…...

10-Oracle 23 ai Vector Search 概述和参数

一、Oracle AI Vector Search 概述 企业和个人都在尝试各种AI&#xff0c;使用客户端或是内部自己搭建集成大模型的终端&#xff0c;加速与大型语言模型&#xff08;LLM&#xff09;的结合&#xff0c;同时使用检索增强生成&#xff08;Retrieval Augmented Generation &#…...

华硕a豆14 Air香氛版,美学与科技的馨香融合

在快节奏的现代生活中&#xff0c;我们渴望一个能激发创想、愉悦感官的工作与生活伙伴&#xff0c;它不仅是冰冷的科技工具&#xff0c;更能触动我们内心深处的细腻情感。正是在这样的期许下&#xff0c;华硕a豆14 Air香氛版翩然而至&#xff0c;它以一种前所未有的方式&#x…...