using GFramework.Core.Abstractions.Logging;
using GFramework.Core.Abstractions.Utility;
using GFramework.Core.Logging;
using GFramework.Core.Rule;
namespace GFramework.Core.Utility;
///
/// 抽象上下文工具类,提供上下文相关的通用功能实现
/// 继承自ContextAwareBase并实现IContextUtility接口
///
public abstract class AbstractContextUtility : ContextAwareBase, IContextUtility
{
///
/// 日志记录器
///
protected ILogger Logger = null !;
///
/// 初始化上下文工具类
///
public void Initialize()
{
var name = GetType().Name;
// 获取上下文中的日志记录器
Logger = LoggerFactoryResolver.Provider.CreateLogger(name);
Logger.Debug($"Initializing Context Utility: {name}");
// 执行子类实现的初始化逻辑
OnInit();
// 记录初始化完成信息
Logger.Info($"Context Utility initialized: {name}");
}
///
/// 销毁上下文工具类实例
///
public void Destroy()
{
var name = GetType().Name;
Logger.Debug($"Destroying Context Utility: {name}");
OnDestroy();
Logger.Info($"Context Utility destroyed: {name}");
}
///
/// 抽象初始化方法,由子类实现具体的初始化逻辑
///
protected abstract void OnInit();
///
/// 虚拟销毁方法,可由子类重写以实现自定义销毁逻辑
///
protected virtual void OnDestroy()
{
}
}