Рассмотрим этот пример, он показывает два возможных способа ленивой инициализации. За исключением того, что они являются потокобезопасными, существуют ли какие-либо конкретные преимущества использования Lazy <T> здесь?
class Customer {
private decimal? _balance2;
private static decimal GetBalanceOverNetwork() {
//lengthy network operations
Thread.Sleep(2000);
return 99.9M;
}
public decimal? GetBalance2Lazily() {
return _balance2 ?? (_balance2 = GetBalanceOverNetwork());
}
private readonly Lazy<decimal> _balance1 = new Lazy<decimal>(GetBalanceOverNetwork);
public Lazy<decimal> Balance1 {
get { return _balance1; }
}
}
UPDATE:
Пожалуйста, рассмотрите вышеприведенный код как простой пример, типы данных не имеют значения, здесь нужно сравнить Lazy <T> над стандартной ленивой инициализацией.