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

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











