32. 代码优化

1.代码优化


1.代码优化

csharp 复制代码
基于枚举创建不同对象

1).根据工厂和字典模式

public static class BuffEffectFactory
{
    // 字典:枚举 -> 对象构造委托
    private static readonly Dictionary<BuffEffect, Func<BuffEffectBase>> _effectCreators = new();

    static BuffEffectFactory()
    {
        // 预注册所有Buff类型
        _effectCreators.Add(BuffEffect.RebuildCard, () => new RebuildBuffEffect());
        _effectCreators.Add(BuffEffect.ControlDice, () => new ControlDiceBuffEffect());
        _effectCreators.Add(BuffEffect.BuildLvVariation, () => new BuildLvBuffEffect());
        _effectCreators.Add(BuffEffect.AddBuffByCondition, () => new AddBuffEffect());
        _effectCreators.Add(BuffEffect.DirectionChange, () => new DirectionChangeBuffEffect());
    }

    public static BuffEffectBase Create(BuffEffect effectType)
    {
        if (_effectCreators.TryGetValue(effectType, out var creator))
        {
            return creator();
        }
        throw new ArgumentOutOfRangeException(nameof(effectType), $"未注册的Buff类型:{effectType}");
    }
}

csharp 复制代码
2).通过特性和反射的方式

// 1. 定义特性:标记类对应的枚举值
[AttributeUsage(AttributeTargets.Class)]
public class BuffEffectAttribute : Attribute
{
    public BuffEffect EffectType { get; }
    public BuffEffectAttribute(BuffEffect effectType) => EffectType = effectType;
}

// 2. 给Buff类标记特性
[BuffEffect(BuffEffect.RebuildCard)]
public class RebuildBuffEffect : BuffEffectBase { }

[BuffEffect(BuffEffect.ControlDice)]
public class ControlDiceBuffEffect : BuffEffectBase { }
csharp 复制代码
static BuffEffectFactory()
{
    // 优化1:只扫描指定程序集(避免遍历所有程序集,减少扫描量)
    var targetAssembly = Assembly.GetExecutingAssembly(); // 假设Buff类都在当前程序集
    var buffTypes = targetAssembly.GetTypes()
        .Where(type => typeof(BuffEffectBase).IsAssignableFrom(type) 
                     && !type.IsAbstract 
                     && type.GetCustomAttribute<BuffEffectAttribute>() != null);

    foreach (var type in buffTypes)
    {
        var attribute = type.GetCustomAttribute<BuffEffectAttribute>();
        if (attribute == null) continue;

        // 优化2:缓存构造函数委托,替代Activator.CreateInstance
        var constructor = type.GetConstructor(Type.EmptyTypes); // 无参构造
        if (constructor == null)
        {
            throw new InvalidOperationException($"{type.Name} 必须提供无参构造函数");
        }
        // 将构造函数转为委托,调用时无反射损耗
        var creator = (Func<BuffEffectBase>)Delegate.CreateDelegate(
            typeof(Func<BuffEffectBase>), constructor);
        
        _effectCreators.Add(attribute.EffectType, creator);
    }
}
相关推荐
tealcwu6 小时前
【Unity实战】Unity IAP 4.x 在 Windows Store (UWP) 平台上的实现指南
windows·unity·游戏引擎
玉夏6 小时前
【Shader基础】CG/HLSL 基础语法
unity·shader
垂葛酒肝汤9 小时前
Unity的UGUI的坐标
unity
winlife_9 小时前
让 AI 写敌人状态机,并用脚本化场景验证状态转换正确:funplay-unity-mcp 实战
人工智能·unity·游戏引擎·ai编程·状态机·mcp
tealcwu9 小时前
【Unity实战】Unity IAP 5.3 中实现 Windows Custom Store 实战教程
windows·unity·游戏引擎
unityのkiven10 小时前
工作分享1(26.5.27):基于栈实现全局返回逻辑通用架构设计(适配异步 + 确认弹窗)
游戏·unity·c#·客户端架构
winlife_1 天前
在 Unity 里用 AI 做游戏:funplay-unity-mcp 从安装到第一次让 AI 改场景
人工智能·游戏·unity·ai编程·claude·mcp
qq_205279051 天前
Unity 运行时候会时不时卡顿一下,哪怕是空场景
unity·游戏引擎
美团骑手阿豪1 天前
Unity UGUI自适应分辨率
unity·游戏引擎
LONGZETECH1 天前
软硬协同+故障注入:无人机仿真维修与操控仿真底层算法逻辑拆解
大数据·c语言·算法·3d·unity·无人机