延迟初始化通过推迟对象创建提升启动性能,适用于ASP.net Core等场景,使用Lazy<T>封装重型依赖,结合线程安全模式优化资源消耗与性能平衡。

在 .NET 应用中,延迟初始化(Lazy Initialization)能有效提升启动性能,核心在于推迟对象创建直到真正需要时才执行。应用启动阶段通常会加载大量服务和组件,若全部在启动时实例化,会导致冷启动时间变长、资源占用高。通过延迟初始化,可以将部分开销较大的对象创建操作延后,从而加快初始加载速度。
减少启动时的资源消耗
某些对象在初始化时可能涉及文件读取、数据库连接、网络请求或复杂计算。如果这些对象并非在程序启动后立即使用,提前创建只会浪费 CPU 和内存资源。
使用 Lazy<T> 可确保对象只在第一次访问其 Value 属性时才被构造:
- 避免在构造函数或启动逻辑中直接 new 实例
- 把耗时操作封装到 Lazy 包装中
- 仅当实际调用 Value 时才触发初始化逻辑
优化依赖注入中的服务加载
在 ASP.NET Core 等框架中,即使注册为单例的服务,也可以结合 Lazy<T> 实现延迟解析。例如:
public class SomeService { private readonly Lazy<HeavyDependency> _heavyDep; public SomeService(Lazy<HeavyDependency> heavyDep) { _heavyDep = heavyDep; } public void DoWork() { // 只有在此处才会创建 HeavyDependency var dep = _heavyDep.Value; dep.Process(); } }
这样即使 SomeService 在启动时就被注入,HeavyDependency 的实例仍不会立即创建,除非 DoWork 被调用。
支持线程安全与性能平衡
.NET 的 Lazy<T> 提供多种初始化模式,可通过 LazyThreadSafetyMode 控制并发行为:
- ExecutionAndPublication:确保多线程下只初始化一次,适合大多数场景
- PublishOnFirstWrite:轻量级线程安全,适用于高性能要求的场合
- None:无锁,仅用于单线程环境
合理选择模式可在保证正确性的同时减少同步开销。
基本上就这些。延迟初始化不是万能方案,但对那些“可能用到、但不一定会用”的重型对象来说,它是优化启动性能的实用手段。关键是识别出哪些组件适合延迟创建,并用 Lazy<T> 合理封装,让应用启动更快、更轻盈。


