请解释 .NET 中的"反射(Reflection)"是什么?它的优缺点以及典型应用场景是什么?
参考答案:
在 .NET 中,反射(Reflection) 是一种在运行时获取程序集、类型、方法、属性等元数据,并对其进行操作的机制。通过反射,程序可以在不知道具体类型的情况下,动态地创建对象、调用方法或访问属性。
反射的核心在于:
👉 在运行时操作类型信息(Type Metadata)
常见的反射功能包括:
获取类型信息(Type)
动态创建对象(Activator.CreateInstance)
调用方法(MethodInfo.Invoke)
读取/设置属性(PropertyInfo)
反射的优点:
高度灵活:可以动态加载和操作未知类型
解耦代码:减少对具体实现的依赖
支持框架开发:如依赖注入、ORM、序列化等
反射的缺点:
性能较低(相比直接调用)
缺乏编译期检查(容易出错)
代码可读性较差
因此,反射通常用于框架层或基础设施层,而不是业务逻辑中频繁使用。
追问 1
为什么反射性能较低?如何优化?
答案:
反射性能较低的主要原因是:它是在运行时解析类型信息,并通过元数据进行动态调用,这比编译期确定的方法调用多了额外的开销,例如查找方法、参数匹配、权限检查等。
优化方式包括:
缓存反射结果(如缓存 Type、MethodInfo)
使用 表达式树(Expression) 生成委托替代反射调用
使用 Delegate.CreateDelegate 提高调用效率
在高性能场景中,通常不会直接频繁使用反射,而是通过"反射 + 缓存"或"反射 + 编译优化"的方式提升性能。
追问 2
反射在实际开发中的典型应用有哪些?
答案:
反射在 .NET 生态中应用非常广泛,尤其是在框架层。例如:
依赖注入(DI)容器:扫描程序集并自动注册服务
ORM 框架(如 Entity Framework):映射数据库表与实体类
序列化/反序列化(JSON/XML):动态读取对象属性
插件系统:动态加载外部程序集
特性(Attribute)处理:通过反射读取元数据驱动行为
这些场景的共同特点是:需要在运行时动态处理类型信息,而不是在编译期固定逻辑。
#面试题 #dotnet面试题 #面试真题
