mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-03-22 19:03:29 +08:00
- 将所有小写的命名空间导入更正为首字母大写格式 - 统一 GFramework 框架的命名空间引用规范 - 修复 core、ecs、godot 等模块的命名空间导入错误 - 标准化文档示例代码中的 using 语句格式 - 确保所有文档中的命名空间引用保持一致性 - 更新 global using 语句以匹配正确的命名空间格式
62 lines
1.6 KiB
C#
62 lines
1.6 KiB
C#
using GFramework.Core.Abstractions.Enums;
|
|
using GFramework.Core.Abstractions.Logging;
|
|
using GFramework.Core.Abstractions.System;
|
|
using GFramework.Core.Logging;
|
|
using GFramework.Core.Rule;
|
|
|
|
namespace GFramework.Core.System;
|
|
|
|
/// <summary>
|
|
/// 抽象系统基类,实现系统接口的基本功能
|
|
/// 提供架构关联、初始化和销毁机制
|
|
/// </summary>
|
|
public abstract class AbstractSystem : ContextAwareBase, ISystem
|
|
{
|
|
private ILogger _logger = null!;
|
|
|
|
/// <summary>
|
|
/// 系统初始化方法,调用抽象初始化方法
|
|
/// </summary>
|
|
public void Initialize()
|
|
{
|
|
var name = GetType().Name;
|
|
_logger = LoggerFactoryResolver.Provider.CreateLogger(name);
|
|
_logger.Debug($"Initializing system: {name}");
|
|
|
|
OnInit();
|
|
|
|
_logger.Info($"System initialized: {name}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// 系统销毁方法,调用抽象销毁方法
|
|
/// </summary>
|
|
public void Destroy()
|
|
{
|
|
_logger.Debug($"Destroying system: {GetType().Name}");
|
|
|
|
OnDestroy();
|
|
|
|
_logger.Info($"System destroyed: {GetType().Name}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// 处理架构阶段事件的虚拟方法
|
|
/// </summary>
|
|
/// <param name="phase">当前的架构阶段</param>
|
|
public virtual void OnArchitecturePhase(ArchitecturePhase phase)
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// 抽象初始化方法,由子类实现具体的初始化逻辑
|
|
/// </summary>
|
|
protected abstract void OnInit();
|
|
|
|
/// <summary>
|
|
/// 抽象销毁方法,由子类实现具体的资源清理逻辑
|
|
/// </summary>
|
|
protected virtual void OnDestroy()
|
|
{
|
|
}
|
|
} |