.NET 中的源生成器如何减少运行时反射?

来源:这里教程网 时间:2026-02-21 17:28:09 作者:

.NET 中的源生成器通过在编译时生成代码来替代运行时反射,从而提升性能和减少开销。反射虽然灵活,但在运行时查询类型信息、调用方法或访问属性会带来性能损耗,并增加内存占用。源生成器可以在编译期间分析代码并自动生成所需实现,避免了这些运行时操作。

编译时生成代替运行时探查

源生成器在编译阶段扫描用户的代码,根据特定模式或属性自动生成辅助代码。例如,一个标记了 [JsonSerializable] 的类型,源生成器可以提前生成序列化和反序列化逻辑,而无需在运行时使用反射去读取字段或属性。

这种方式将原本需要在程序运行时“边查边做”的工作,转移到编译期“预先做好”,显著减少了启动时间和执行延迟。

消除对动态类型的依赖

很多基于反射的库(如 ORM 或序列化框架)依赖运行时创建对象实例或读写属性。使用源生成器后,这些操作可以通过强类型、预生成的方法完成。

例如,Entity Framework Core 7+ 使用源生成器为实体类型生成高效的创建工厂和属性访问器,不再依赖 Activator.CreateInstance 或动态委托。 System.Text.Json 源生成器可为每个目标类型生成专用的序列化器,完全绕过反射路径。

生成高效中间代码

源生成器不仅能避免反射,还能生成高度优化的代码。比如:

直接调用属性的 getter/setter,而不是通过 PropertyInfo.SetValue 使用常量字符串或已知类型信息,启用更多 JIT 优化。 省略不必要的空检查或异常处理路径(在已知安全场景下)。

这些生成的代码与手写代码性能接近,远快于通用反射逻辑。

基本上就这些。源生成器不是完全取代反射,而是把原本必须在运行时做的元数据操作,挪到编译时完成,既保留了灵活性,又获得了性能优势。

相关推荐