反射是C#在运行时动态查看、检查和操作类型及成员的能力,依赖System.Type等类实现,关键在于“运行时”和“动态”,支持加载程序集、创建实例、调用方法;常用Type获取方式包括typeof、GetType()、Type.GetType()和Assembly.GetType();可通过GetMethods()等方法发现成员并用BindingFlags筛选;支持Activator.CreateInstance()创建对象、Invoke()调用方法、GetValue()/SetValue()读写属性或字段;但性能较低,需注意异常处理、权限限制及混淆影响。

反射是C#在运行时查看、检查甚至操作类型、方法、属性、字段等元数据的能力。它不依赖编译期已知的类型,而是通过 System.Type 和相关类,在程序执行中动态发现和调用成员。关键在于“运行时”和“动态”——你不需要提前写死类名或方法名,也能加载程序集、创建实例、调用方法。
要使用反射,第一步是拿到 Type 实例:
typeof(MyClass) —— 编译期已知类型,最轻量、推荐用于本程序内类型obj.GetType() —— 对已有实例获取其实际运行时类型(支持多态)Type.GetType("Namespace.ClassName") —— 通过完整字符串名称获取,需注意命名空间+程序集限定(如未指定,默认只查当前程序集)Assembly.GetExecutingAssembly().GetType("...") —— 显式从指定程序集中查找,适合插件或外部DLL场景拿到 Type 后,可用一系列 GetXXX() 方法列出成员:
type.GetMethods() 返回所有公共方法;加 BindingFlags 可控制可见性(如 BindingFlags.NonPublic | BindingFlags.Instance 查私有实例方法)type.GetProperties()、type.GetFields()、type.GetConstructors() 同理BindingFlags.Public | BindingFlags.Instance 查公有实例成员;BindingFlags.Static | BindingFlags.FlattenHierarchy 查静态继承成员type.GetMethods().Where(m => m.Name.StartsWith("Get"))
反射不仅看,还能做:
Activator.CreateInstance(type)(调用无参构造);或传入参数数组调用带参构造methodInfo.Invoke(obj, args),第一个参数是目标实例(静态方法传 null)propertyInfo.GetValue(obj) / propertyInfo.SetValue(obj, value)
fieldInfo.GetValue(obj) / fieldInfo.SetValue(obj, value)(对私有字段也有效)反射灵活但有代价:
MethodInfo 或用 Delegate.CreateDelegate 转为委托TargetInvocationException 或 ArgumentException,务必做好 try-catchReflectionPermission 已废弃,但部分策略仍影响行为)[DynamicDependency] 或 PreserveAttribute 标记基本上就这些。反射不是日常首选,但在序列化、ORM、DI容器、测试模拟、插件系统等场景中不可替代——理解它怎么“看”和“动”,才能用得稳、改得准、查得清。
以上就是C#中的反射(Reflection)机制 - 如何在运行时动态获取类型信息的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号