C#如何使用Lazy类型 C#延迟初始化使用方法

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

Lazy 是 C# 中用于实现延迟初始化(Lazy Initialization)的核心类型,它确保某个对象或值只在第一次被访问时才创建,之后重复访问直接返回已创建的实例。这能节省资源、避免不必要的计算或 I/O,尤其适合开销大、可能不被使用的对象。

什么时候该用 Lazy

适用于以下场景:

对象构造成本高(如数据库连接、大型配置加载、文件读取) 对象可能在整个生命周期中都不会被用到 需要线程安全的单次初始化(默认支持) 想把“创建时机”从声明/构造阶段推迟到真正使用时

基本用法:最简初始化

直接传入一个工厂函数(Func),首次访问 Value 属性时触发创建:

(C# 6+ 推荐写法)

private readonly Lazy<List<string>> _heavyList = new(() => LoadFromDatabase());

调用时只需:

var data = _heavyList.Value; // 第一次调用才执行 LoadFromDatabase()

控制线程安全与初始化时机

Lazy 构造时可选 LazyThreadSafetyMode 枚举:

LazyThreadSafetyMode.ExecutionAndPublication
(默认):多线程下保证只初始化一次,且线程安全
LazyThreadSafetyMode.PublicationOnly
:允许多次初始化,但只发布第一个成功结果(轻量级,适合无副作用的工厂)
LazyThreadSafetyMode.None
:完全不加锁,仅限单线程场景(性能最高)

例如禁用线程安全(确认是单线程):

var lazy = new Lazy<int>(() => ExpensiveCalc(), LazyThreadSafetyMode.None);</int>

配合属性封装更自然

常与只读属性结合,隐藏 Lazy 实现细节:

private readonly Lazy<HttpClient> _httpClient = new(() => new HttpClient());<br>public HttpClient Client => _httpClient.Value;

外部调用

obj.Client
就像普通属性,实际按需创建,干净又高效。

基本上就这些。用好 Lazy 能让初始化逻辑更可控、更轻量,不复杂但容易忽略。

相关推荐