Java多线程+IO流+网络编程+MySQL+JDBC编程实现多人联机版坦克大战

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 该项目为博主与几位伙伴的共同成果,历时1个月,由最初知识尚未掌握,到最后开发出完整项目,一途走过不少弯路,但也对个人的编程能力及对java知识的掌握更进一步,游戏逻辑主要参考【马士兵网络版坦克大战】

Java多人联机版坦克大战


1.游戏介绍:

该游戏涵盖多线程、IO、网络编程、JDBC知识,实现多人联机版坦克大战。


编码方式:GBK


MySQL jar包版本:mysql-connector-java-8.0.28(已上传至gitee)


jdk版本:1.8


2.游戏启动流程:


需要先在本地的建立MySQL数据库bjpowernode,建表create table userlist(username varchar(255),password int);,可以在表中存储用户名和密码,也可以不存储。


在Main包下启动TankServer端,然后在login包下启动LoginServer,最后启动LogOnFrm出现登录界面,如果数据库中已经存有的用户名和密码,直接登录即可,若不存在,点击两下完成注册,登录成功以后会跳转到游戏界面,按下c键完成IP号和端口号的设置,通过连接同一IP的方式完成多人联机。


在游戏中wasd控制坦克的移动,空格键完成射击。


3.项目类的主要说明:


3.1Game包


微信图片_20230110224924.png

在该包下为坦克大战游戏物体的主要实现,NetClint端为网络联机客户端的实现


  • NetClient类为网络交互功能中客户端的实现类,在该类中与服务器完成连接后可以发送坦克新诞生的消息,再让服务器传输给其他的客户端以实现同步,在client端中的关键代码为UDP接受线程,不断的接受其他的客户端传给服务器,服务器又传给该客户端的UDP包,在该UDPRecvThread中利用信息的封装性,调用send方法完成拆包,拆包的具体细节在各自的信息中具体实现。

  • Dir类为方向枚举类,用以为坦克和子弹的方向属性使用

  • Tank类为坦克逻辑的具体实现,每一辆坦克都有自己独一无二的ID号,在NetClient端启动时根据坦克的id号的奇偶性绘制不同的坦克

  • Explode类为爆炸类,在塔克被击中时产生爆炸特效,利用TankClient端的重绘线程实现多张图片切换出现从而产生爆炸的效果

  • Missile类为子弹类,根据坦克的id也对应绘制出不同颜色的子弹图片,注意在子弹打中坦克或移出边界后需要及时清除。


3.2 Main包


微信图片_20230110224921.png

运行该项目在该包下操作即可,先启动server端再启动client端,此处的TankClient具体的网络联机在Game包下的NetClient类中实现


  • TankClient类为游戏逻辑的主要实现,是坦克的游戏场所
  • TankServer类为网络交互的服务端的主要实现,该类主要实现UDP线程,接收到客户端的信息后为多个客户端实时的发送消息


微信图片_20230110224917.png

3.3Message包


微信图片_20230110224913.png

该包用以实现网络版的信息传输,不同的信息都实现Msg接口,在Msg接口中的send和parse抽象方法,在各自的类中重写send和parse方法(当信息传输过来时在对应的类中完成发包和拆包的具体实现),这样使得这两个方法很好的包装,在client端和server端传输信息时通过多态实现不同类别信息的传输。


  • 代表坦克诞生的消息类 TankNewMsg
  • 代表坦克改变方向的消息类 TankMoveMsg
  • 代表坦克被击毙的消息类 TankDeadMsg
  • 代表子弹产生的消息类 MissileNewMsg
  • 代表子弹消失的消息类 MissileDeadMsg


3.4 login包

通过连接JDBC实现用户登录界面,完成与数据库的交互,实现登录跳转

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
关系型数据库 MySQL Java
【MySQL+java+jpa】MySQL数据返回项目的感悟
【MySQL+java+jpa】MySQL数据返回项目的感悟
44 1
|
1月前
|
关系型数据库 MySQL Java
【IDEA】java后台操作mysql数据库驱动常见错误解决方案
【IDEA】java后台操作mysql数据库驱动常见错误解决方案
64 0
|
3月前
|
前端开发 关系型数据库 MySQL
【前端学java】MySQL数据库的本地安装
【8月更文挑战第12天】MySQL数据库的本地安装
47 3
|
22天前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
|
1月前
|
关系型数据库 MySQL Java
java协程操作mysql数据库
本文介绍了如何在Java项目中使用虚拟线程和协程操作MySQL数据库,并通过代码示例展示了如何利用CompletableFuture实现非阻塞数据库连接和操作。
26 2
java协程操作mysql数据库
|
1月前
|
Java 关系型数据库 MySQL
【编程基础知识】Eclipse连接MySQL 8.0时的JDK版本和驱动问题全解析
本文详细解析了在使用Eclipse连接MySQL 8.0时常见的JDK版本不兼容、驱动类错误和时区设置问题,并提供了清晰的解决方案。通过正确配置JDK版本、选择合适的驱动类和设置时区,确保Java应用能够顺利连接MySQL 8.0。
137 1
|
2月前
|
存储 关系型数据库 MySQL
【Java面试题汇总】MySQL数据库篇(2023版)
聚簇索引和非聚簇索引、索引的底层数据结构、B树和B+树、MySQL为什么不用红黑树而用B+树、数据库引擎有哪些、InnoDB的MVCC、乐观锁和悲观锁、ACID、事务隔离级别、MySQL主从同步、MySQL调优
【Java面试题汇总】MySQL数据库篇(2023版)
|
2月前
|
自然语言处理 算法 Java
Java如何判断两句话的相似度类型MySQL的match
【9月更文挑战第1天】Java如何判断两句话的相似度类型MySQL的match
26 2
|
3月前
|
安全 Java 关系型数据库
Java连接Mysql SSL初始化失败
Java连接Mysql SSL初始化失败
|
3月前
|
存储 SQL 关系型数据库
深入MySQL锁机制:原理、死锁解决及Java防范技巧
深入MySQL锁机制:原理、死锁解决及Java防范技巧