C#中类的反射以及调用小妙招

C#中类的反射以及调用小妙招

介绍

最近看到原来同事写的代码感叹了一下,优化这个东西确实是永无止境的,其实就是不了解类的反射和返回值的使用。

原始代码

csharp 复制代码
public void OnExit(Frame f, QFSMAnimatorEnum state, PlayerFSMRef playerFSMRef)
{
	switch (status)
    {
    	case QFSMAnimatorEnum.None:
            break;
        case QFSMAnimatorEnum.Idle:
            QFSMAnimatorStateIdle.OnExit(f, playerFSMRef);
            break;
        case QFSMAnimatorEnum.Run:
        	QFSMAnimatorStateRun.OnExit(f, playerFSMRef);
	        break;
       	case QFSMAnimatorEnum.HasFrisbeeIdle:
        	QFSMAnimatorStateHasFrisbeeIdle.OnExit(f, playerFSMRef);
            break;
        case QFSMAnimatorEnum.HasFrisbeeRun:
            QFSMAnimatorStateHasFrisbeeRun.OnExit(f, playerFSMRef);
            break;
        case QFSMAnimatorEnum.ReceivingFrisbee:
            QFSMAnimatorStateReceivingFrisbee.OnExit(f, playerFSMRef);
            break;
        case QFSMAnimatorEnum.ThrowingFrisbeeL:
            QFSMAnimatorStateThrowingFrisbeeL.OnExit(f, playerFSMRef);
            break;
        case QFSMAnimatorEnum.ThrowingFrisbeeR:
            QFSMAnimatorStateThrowingFrisbeeR.OnExit(f, playerFSMRef);
            break;
      	case QFSMAnimatorEnum.ThrowingFrisbeeH:
            QFSMAnimatorStateThrowingFrisbeeH.OnExit(f, playerFSMRef);
            break;
        default:
            break;            
    }
}

当你看到上面的代码的时候你发现重复性质的调用太多了,写起来会非常累

类的反射

csharp 复制代码
	Type stateType = Type.GetType($"Namespace.QFSMAnimatorState{status}");
    if (stateType != null)
    {
        MethodInfo onExitMethod = stateType.GetMethod("OnExit");
        onExitMethod?.Invoke(null, new object[] { f, playerFSMRef });
    }

注意:使用这个反射时 Type.GetType($"Namespace.XXXXClass")要加上类的命名空间和类名称
GetMethod("xxx")可以获取反射的类的方法
?.Invoke()方法是有一个object类型的返回值,就是对应方法的返回值(需要自己拆箱处理转成原返回值类型)

修改之后的代码

csharp 复制代码
public void OnExit(Frame f, QFSMAnimatorEnum state, PlayerFSMRef playerFSMRef)
{
	switch (status)
	{
    	case QFSMAnimatorEnum.None:
        	break;
    	default:
        	Type stateType = Type.GetType($"Namespace.QFSMAnimatorState{status}");
        	if (stateType != null)
        	{
            	MethodInfo onExitMethod = stateType.GetMethod("OnExit");
            	onExitMethod?.Invoke(null, new object[] { f, playerFSMRef });
        	}
        	break;
	}
}

上述的代码是优化之后的代码,这里其实就是用到了一个反射并且调用了反射类的方法

总结

优化永无止境。感谢大家的支持!

相关推荐
时光追逐者1 小时前
C#/.NET/.NET Core技术前沿周刊 | 第 35 期(2025年4.14-4.20)
c#·.net·.netcore
@蓝莓果粒茶2 小时前
LeetCode第158题_用Read4读取N个字符 II
前端·c++·python·算法·leetcode·职场和发展·c#
码观天工3 小时前
.NET 原生驾驭 AI 新基建实战系列(四):Qdrant ── 实时高效的向量搜索利器
c#·.net·向量数据库·qdrant
稀饭过霍4 小时前
C# .NET如何自动实现依赖注入(DI)
java·c#·.net
佟格湾4 小时前
聊透多线程编程-线程互斥与同步-13. C# Mutex类实现线程互斥
c#·多线程
全栈小55 小时前
【C#】.net core 6.0调用MVC API接口时,提示Unsupported Media Type,状态码415
c#·mvc·.netcore
vrlab1236 小时前
C#+Visual Studio 2022为AutoCAD 2022开发插件并显示在Ribbon选项卡
ribbon·c#·visual studio
佟格湾16 小时前
聊透多线程编程-线程互斥与同步-11. C# lock关键字实现线程互斥
c#·多线程
Dm_dotnet21 小时前
在Avalonia/C#中使用依赖注入过程记录
c#