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

Unity3D ET框架游戏脚本系统解析

前言

ET框架在Unity3D中实现的GamePlay脚本系统是一种革命性的、基于ECS(实体-组件-系统)架构的设计,它彻底改变了传统的基于MonoBehaviour的游戏逻辑编写方式。其核心思想是追求高性能、高解耦、易热更新,特别适合大型复杂的网络游戏(如MMO、MOBA、卡牌等)。

对惹,这里有一个游戏开发交流小组,希望大家可以点击进来一起交流一下开发经验呀!

以下是这种脚本系统的关键特性和工作原理:

  1. 核心:ECS架构
  • Entity (实体): 不再是GameObject,而是一个纯数据容器的轻量级ID。它本身不包含任何逻辑,只代表游戏世界中的一个“东西”(如玩家、怪物、技能、Buff、甚至一个计时器)。
  • Component (组件): 是纯数据的结构体(C# struct)。它们附着在实体上,描述实体的状态(如TransformComponent - 位置/旋转/缩放,MoveComponent - 移动目标/速度,UnitComponent - 基础属性,BuffComponent - 持有的Buff列表)。组件没有任何方法。
  • System (系统): 是纯逻辑的类(C# class)。它们持有状态,而是遍历拥有特定组件组合的实体,并在每一帧(或特定时机)对这些实体执行相应的逻辑操作(如MoveSystem处理所有拥有TransformComponentMoveComponent的实体的移动逻辑,SkillSystem处理技能释放和效果应用)。系统是单例的。

  1. 摒弃 MonoBehaviour
  • 传统的Unity开发严重依赖挂在GameObject上的MonoBehaviour脚本,这些脚本混合了数据、逻辑,并且与Unity引擎深度耦合(生命周期方法如UpdateStart等)。
  • ET框架几乎完全避免使用MonoBehaviour来编写核心游戏逻辑GameObject及其MonoBehaviour仅被视为表现层(View),用于处理渲染、动画、声音、碰撞体(物理交互仍需通过Unity回调)等与引擎表现相关的内容。

  1. 逻辑与表现分离
  • 逻辑层 (Server/Client Logic): 完全运行在ECS框架内,处理核心的游戏规则、状态计算、网络同步等。这部分代码是平台无关的(不直接依赖Unity API),主要操作Entity和Component。
  • 表现层 (View): 使用少量的GameObjectMonoBehaviour(通常称为UnitViewEffectView等)来反映逻辑层实体的状态。表现层通过监听逻辑层组件的变化(如位置变化、播放动画事件、创建销毁事件)来驱动Unity引擎的渲染和表现。
  • 分离的好处:
    • 性能: ECS的数据布局和System的批处理执行更利于CPU缓存,避免虚函数调用(MonoBehaviour.Update),性能显著高于大量MonoBehaviour
    • 解耦: 逻辑代码不依赖Unity引擎和GameObject,可独立测试、更容易移植。
    • 热更新: 核心逻辑代码(C#)可以打包成动态链接库(DLL),通过ILRuntime或HybridCLR等技术实现热更新,无需重新安装包体。表现层代码通常不热更或热更需求较少。
    • 清晰性: 数据(Component)和逻辑(System)分离,代码结构更清晰,易于理解和维护。

  1. 基于事件的异步编程 (async/await)
  • ET框架深度拥抱C#的async/await异步模型来处理网络通信、资源加载、计时器等耗时或需要等待的操作。
  • 游戏逻辑代码(System中的方法)可以写成线性的异步形式,避免了回调地狱(Callback Hell),极大地提高了网络游戏逻辑代码的可读性和可维护性。例如,等待一个技能吟唱完成、等待服务器响应、顺序加载多个资源等操作,代码写起来像同步一样清晰。

  1. 强大的网络同步支持
  • ET框架内置了高性能的网络库(基于TCP或KCP协议)。
  • ECS架构天然适合网络同步。只需要同步发生变化的组件数据即可。
  • 框架提供了RPC(远程过程调用)机制,方便客户端与服务器通信。
  • 状态同步在System中处理,例如MoveSystem检测MoveComponent的变化并同步位置。

  1. 生命周期管理
  • 实体的创建、添加/删除组件、销毁等都有明确的事件和机制(如AwakeSystemDestroySystem)。
  • 框架提供了对象池(ObjectPool)来高效管理Entity和Component的创建与回收,减少GC压力。

  1. 优势总结:
  • 高性能: ECS架构和避免MonoBehaviour开销带来显著的性能提升。
  • 高解耦 & 清晰架构: 严格的ECS分离(数据/逻辑)、逻辑/表现分离,使代码结构清晰,模块化程度高。
  • 卓越的热更新能力: 核心逻辑代码易于热更新。
  • 强大的网络支持: 为网络游戏量身定制。
  • 异步友好:async/await模型极大简化异步逻辑编写。
  • 跨平台潜力: 逻辑层代码不依赖Unity,理论上可移植到其他引擎或服务器。

  1. 挑战与学习曲线:
  • 思维转变: 需要从传统的面向对象/MonoBehaviour思维模式转换到ECS的数据驱动和面向组合思维模式。
  • 架构设计: 如何合理地划分Component和System,设计数据结构和事件流,需要良好的设计能力。
  • 学习成本: ET框架本身有一定的学习成本,需要理解其ECS实现、网络模型、异步机制、生命周期等。
  • 热更新复杂性: 虽然支持热更新,但其配置和使用(ILRuntime/HybridCLR)本身也有技术门槛和注意事项。
  • 调试: 纯ECS逻辑的调试可能不如MonoBehaviour直观,需要借助日志和框架提供的工具。

结论:

Unity3D基于ET框架开发的GamePlay脚本系统是一种面向高性能、大型复杂网络游戏(尤其是需要热更新的) 的先进架构方案。它通过彻底的ECS实现、逻辑与表现分离、深度拥抱async/await异步,解决了传统MonoBehaviour方式在性能、架构清晰度、热更新和网络同步方面的痛点。虽然学习曲线较陡且需要思维转换,但一旦掌握,它能带来开发效率和运行时性能的巨大提升,是开发大型商业Unity网络游戏的强力选择。选择ET框架意味着选择了更底层、更可控、更高性能但也更复杂的一条开发道路。

更多教学视频

Unity3D​www.bycwedu.com/promotion_channels/2146264125

相关文章:

Unity3D ET框架游戏脚本系统解析

前言 ET框架在Unity3D中实现的GamePlay脚本系统是一种革命性的、基于ECS(实体-组件-系统)架构的设计,它彻底改变了传统的基于MonoBehaviour的游戏逻辑编写方式。其核心思想是追求高性能、高解耦、易热更新,特别适合大型复杂的网络…...

函数的定义、调用、值传递、声明、非安全函数

函数 函数(英文“function”)把一些经常用到的代码封装起来,这样可以减少一些冗余代码、重复的代码。一个大的程序,它是由很多很多程序块组成的,每个模块实现一个特定的功能。 函数的定义 格式 英文版 return_typ…...

MySQL 8.0 OCP 英文题库解析(十一)

Oracle 为庆祝 MySQL 30 周年,截止到 2025.07.31 之前。所有人均可以免费考取原价245美元的MySQL OCP 认证。 从今天开始,将英文题库免费公布出来,并进行解析,帮助大家在一个月之内轻松通过OCP认证。 本期公布试题91~100 试题91…...

机器学习算法-k-means

今天我们用 「超市顾客分组」 的例子来讲解K-means算法,从原理到实现一步步拆解,保证零基础也能懂! 🛒 例子背景 假设你是超市经理,手上有顾客的以下数据: 顾客ID每月消费金额(元)…...

ADQ36-2通道2.5G,4通道5G采样PXIE

ADQ36是一款高端12位四通道灵活数据采集板,针对高通道数科学应用进行了优化。ADQ36具有以下特性: 4 / 2模拟输入通道每通道2.5 / 5 GSPS7gb/秒的持续数据传输速率两个外部触发器通用输入/输出(GPIO)ADQ36数字化仪包括固件FWDAQ ADQ36简介 特…...

LLM:decoder-only 思考

文章目录 前言一、KV-cache1、为什么使用KV-cache2、KV-cache的运作原理 二、Decoder-only VS Encoder-Decoder1、Decoder-only2、Encoder-Decoder 三、Causal LM VS PrefixLM总结 前言 decoder-only模型是目前大模型的主流架构,由于OpenAI勇于挖坑踩坑&#xff0c…...

数字创新智慧园区建设及运维方案

该文档是 “数字创新智慧园区” 建设及运维方案,指出传统产业园区存在管理粗放等问题,“数字创新园区” 通过大数据、AI、物联网、云计算等数字化技术,旨在提升园区产业服务、运营管理水平,增强竞争力,实现绿色节能、高效管理等目标。建设内容包括智能设施、核心支撑平台、…...

【科研绘图系列】R语言绘制森林图(forest plot)

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍加载R包数据下载导入数据数据预处理画图系统信息介绍 本文介绍使用R语言绘制森林图(forest plot)的方法。首先加载必要的R包(grid、forestploter、openxlsx、stringr),导入并预处…...

Springcloud Alibaba自定义负载均衡详解

主要说一下springcloud alibaba 在使用nacos注册中心过程中&#xff0c;请求服务负载均衡的配置方法 引入依赖包 这个依赖包是springcloud在新版本的负载均衡实现&#xff0c;2020版本以上 <dependency><groupId>org.springframework.cloud</groupId><ar…...

深度学习---负样本训练

一、负样本的本质与核心作用 1. 定义与范畴 负样本&#xff08;Negative Sample&#xff09;是与目标样本&#xff08;正样本&#xff09;在语义、特征或任务目标上存在显著差异的样本。其核心价值在于通过对比学习引导模型学习样本间的判别性特征&#xff0c;而非仅记忆正样本…...

SpringAI+DeepSeek大模型应用开发实战

内容来自黑马程序员 这里写目录标题 认识AI和大模型大模型应用开发模型部署方案对比模型部署-云服务模型部署-本地部署调用大模型什么是大模型应用传统应用和大模型应用大模型应用 大模型应用开发技术架构 SpringAI对话机器人快速入门会话日志会话记忆 认识AI和大模型 AI的发…...

【Python Cookbook】文件与 IO(一)

文件与 IO&#xff08;一&#xff09; 1.读写文本数据2.打印输出至文件中3.使用其他分隔符或行终止符打印4.读写字节数据5.文件不存在才能写入 1.读写文本数据 你需要读写各种不同编码的文本数据&#xff0c;比如 ASCII&#xff0c;UTF-8 或 UTF-16 编码等。 使用带有 rt 模式…...

STM32 HAL库函数学习 GPIO篇

1、void HAL_GPIO_Init(GPIO_TypeDef *GPIOx, const GPIO_InitTypeDef *pGPIO_Init) GPIO外设属于是任何芯片的最基础功能 &#xff0c;STM32各个系列的GPIO初始化都是一致的&#xff0c;有不同的是部分系列在IO复用使用了单独一个成员属性Alternate 来表明这个IO的具体复用功…...

如何以 9 种方式将照片从 iPhone 传输到笔记本电脑

您的 iPhone 可能充满了以照片和视频形式捕捉的珍贵回忆。无论您是想备份它们、在更大的屏幕上编辑它们&#xff0c;还是只是释放设备上的空间&#xff0c;您都需要将照片从 iPhone 传输到笔记本电脑。幸运的是&#xff0c;有 9 种方便的方法可供使用&#xff0c;同时满足 Wind…...

根据jvm源码剖析类加载机制

根据jvm源码剖析类加载机制 java Test.class之后的大致流程 java Test.class ----> 对于windows操作系统 ----> java.exe调用jvm.dll文件创建JVM&#xff0c; ----> 在创建JVM中先由C的代码创建Boostarp&#xff08;引导&#xff09;类加载器&#xff0c; ----&g…...

Mixly1.0/2.0/3.0 (windows系统) 安装教程及使用常见问题解决

大家好&#xff01;长期以来&#xff0c;不少用户在使用 Mixly 软件过程中遇到了各类问题。为了帮助大家更顺畅地使用该软件&#xff0c;齐护机器人工程师结合自身丰富经验&#xff0c;精心总结并推出了本期教程。在本教程中&#xff0c;我们将从 Mixly 图形化编程软件的安装步…...

DDS通信中间件——DDS-TSN规范

DDS通信中间件——DDS-TSN规范 做了十年DDS通信中间件产品的程序员和大家分享一下对DDS这套规范的个人理解。预期本系列文章将包括以下内容陆续更新&#xff1a; DDS规范概述DCPS规范解读 & QoS策略XTypes规范解读RTPS规范解读DDS安全规范解读DDS-RPC规范解读&#xff08…...

JWT安全:弱签名测试.【实现越权绕过.】

JWT安全&#xff1a;假密钥【签名随便写实现越权绕过.】 JSON Web 令牌 (JWT)是一种在系统之间发送加密签名 JSON 数据的标准化格式。理论上&#xff0c;它们可以包含任何类型的数据&#xff0c;但最常用于在身份验证、会话处理和访问控制机制中发送有关用户的信息(“声明”)。…...

MATLAB实现井字棋

一、智能决策系统与博弈游戏概述 &#xff08;一&#xff09;智能决策系统核心概念 智能决策系统&#xff08;Intelligent Decision System, IDS&#xff09;是通过数据驱动和算法模型模拟人类决策过程的计算机系统&#xff0c;核心目标是在复杂环境中自动生成最优策略&#…...

Baklib知识中台加速企业服务智能化实践

知识中台架构体系构建 Baklib 通过构建多层级架构体系实现知识中台的底层支撑&#xff0c;其核心包含数据采集层、知识加工层、服务输出层及智能应用层。在数据采集端&#xff0c;系统支持对接CRM、ERP等业务系统&#xff0c;结合NLP技术实现非结构化数据的自动抽取&#xff1…...

在AIX环境下修改oracle 11g rac的IP地址

0、当前环境 由于机房网络变更&#xff0c;客户要修改现在RAC的网络地址&#xff0c;这里记录一下。 主机操作系统&#xff1a;AIX 7.2 数据库版本&#xff1a;11.2.0.4 rac 数据库实例名&#xff1a;orcl1/orcl2 当前hosts文件配置 192.168.56.10 rac1 192.168.56.11 …...

VMware Tools 手动编译安装版

OWASPBWA安装VMware tools 安装时&#xff0c;显示如下提示 官方安装手册参考&#xff1a;https://knowledge.broadcom.com/external/article?legacyId1014294 按照提示&#xff0c;下载linux.iso文件&#xff0c;并连接到虚拟机的CDROM里&#xff0c;状态勾选已连接&#x…...

android平台驱动开发(六)--Makefile和Kconfig简介

Makefile&#xff1a; 1.编译进内核&#xff0c;还是以模块方式加载 模块方式编译成ko,通常是自己添加脚本方式insmod ,android 平台通常默认有modprobe加载&#xff0c;不需要额外添加insmod脚本 lsmod |grep test 可以查看是否安装成功 rmmod test-m.ko 可以删除ko 2.多…...

【手写系列】手写线程池

PS&#xff1a;本文的线程池为演示 Demo&#xff0c;皆在理解线程池的工作原理&#xff0c;并没有解决线程安全问题。 最简单一版的线程池 public class MyThreadPool {// 存放线程&#xff0c;复用已创建的线程List<Thread> threadList new ArrayList<>();publ…...

python学习打卡day40

DAY 40 训练和测试的规范写法 知识点回顾&#xff1a; 彩色和灰度图片测试和训练的规范写法&#xff1a;封装在函数中展平操作&#xff1a;除第一个维度batchsize外全部展平dropout操作&#xff1a;训练阶段随机丢弃神经元&#xff0c;测试阶段eval模式关闭dropout 作业&#…...

redis高并发问题

Redlock原理和存在的问题 Redlock 基于以下假设&#xff1a; 有多个&#xff08;一般建议是 5 个&#xff09;彼此独立的 Redis 实例&#xff08;不是主从复制&#xff0c;也不是集群模式&#xff09;&#xff0c;它们之间没有数据同步。客户端可以与所有 Redis 实例通信。 …...

Live Helper Chat 安装部署

Live Helper Chat(LHC)是一款开源的实时客服聊天系统,适用于网站和应用,帮助企业与访问者即时沟通。它功能丰富、灵活、可自托管,常被用于在线客户支持、销售咨询以及技术支持场景。 🧰 系统要求 安装要求 您提供的链接指向 Live Helper Chat 的官方安装指南页面,详细…...

ARXML解析与可视化工具

随着汽车电子行业的快速发展,AUTOSAR标准在车辆软件架构中发挥着越来越重要的作用。然而,传统的ARXML文件处理工具往往存在高昂的许可费用、封闭的数据格式和复杂的使用门槛等问题。本文介绍一种基于TXT格式输出的ARXML解析方案,为开发团队提供了一个高效的替代解决方案。 …...

PnP(Perspective-n-Point)算法 | 用于求解已知n个3D点及其对应2D投影点的相机位姿

什么是PnP算法&#xff1f; PnP 全称是 Perspective-n-Point&#xff0c;中文叫“n点透视问题”。它的目标是&#xff1a; 已知一些空间中已知3D点的位置&#xff08;世界坐标&#xff09;和它们对应的2D图像像素坐标&#xff0c;求解摄像机的姿态&#xff08;位置和平移&…...

LeetCode 热题 100 208. 实现 Trie (前缀树)

LeetCode 热题 100 | 208. 实现 Trie (前缀树) 大家好&#xff01;今天我们来解决一道经典的算法题——实现 Trie (前缀树)。Trie&#xff08;发音类似 “try”&#xff09;是一种树形数据结构&#xff0c;用于高效地存储和检索字符串数据集中的键。这一数据结构在自动补全和拼…...