国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

ASP.NET泛型四之使用Lazy<T>實現延遲加載

瀏覽:94日期:2022-06-08 14:29:25

".NET泛型"系列:

對于一些"大對象"的創(chuàng)建,我們常常希望延遲加載,即在需要的時候再創(chuàng)建對象實例。現在Lazy<T>很好地支持了這一特點。主要包括:

沒有Lazy<T>之前

在沒有Lazy<T>之前,我們通過如下方式實現延遲加載。

public class LazySinleton
{
    private LazySingleton()
    {}
 
    public static LazySingleton Instance
    {
get
{
    return Lazy.data;
}
    }
 
    private class Lazy
    {
static Lazy()
{}
 
internal static readonly LazySingleton data = new LazySingleton();
    }
}

以上

  • 通過私有構造函數屏蔽了LazySingleton類通過構造函數創(chuàng)建的方式
  • 私有嵌套類Lazy的data字段負責提供一個LazySingleton的實例
  • 只能通過LazySingleton的屬性Instance,才能拿到內部類Lazy.data所代表的實例

Lazy<T>實例

先看Lazy<T>的定義:

public class Lazy<T>
{
    public Lazy();
    public Lazy(bool isThreadSafe);
    public Lazy(Func<T> valueFactory);
    public Lazy(LazyThreadSafeMode mode);
    public Lazy(Func<T> valueFactory, bool isThreadSafe);
    public Lazy(Funct<T> valueFactory, LazyThreadSafetyMode mode);

    public bool IsValueCreated{get;}
    public T Value {get;}
    public override string ToStirng();
}

通過Lazy<T>的構造函數重載創(chuàng)建對象,再通過體現延遲加載的Value屬性來實現對象的創(chuàng)建,并獲取對象實例。

public class SomeClass
{
    public int ID{get;set;}
}

Lazy<SomeClass> temp = new Lazy<SomeClass>();
Console.WriteLine(temp.Value.ID);

以上,只適用于沒有構造函數的情況,如果有構造函數如何處理呢?
--使用public Lazy(Func<T> valueFactory),通過委托創(chuàng)建對象

pubic class SomeClass
{
    public int ID{get;set;}
    public SomeClass(int id)
    {
this.ID = id;
    }
}

Lazy<SomeClass> temp = new Lazy<SomeClass>(() => new Big(100));
Console.WriteLine(temp.Value.ID);

延遲加載的本質

創(chuàng)建自定義延遲加載類。

    public class MyLazy<T>
    {
private volatile object boxed; //volatile說明在多線程狀況下,也可以修改該字段
private Func<T> valueFactory; //委托,用來生產T對象實例

static MyLazy(){}
public MyLazy(){}

public MyLazy(Func<T> valueFactory)
{
    this.valueFactory = valueFactory;
}

public T Value
{
    get
    {
Boxed boxed = null;
if (this.boxed != null)
{
    boxed = this.boxed as Boxed;
    if (boxed != null)
    {
return boxed.value;
    }
}
return this.Init();
    }
}

//初始化對象實例
private T Init()
{
    Boxed boxed = null;
    if (this.boxed == null)
    {
boxed = this.CreateValue();
this.boxed = boxed;
    }
    return boxed.value;
}

//創(chuàng)建內部類實例
private Boxed CreateValue()
{
    //如果創(chuàng)建對象實例的委托valueFactory存在
    if (this.valueFactory != null)
    {
//就通過委托生成對象實例
return new Boxed(this.valueFactory());
    }
    else
    {
//否則,通過反射生成對象實例
return new Boxed((T)Activator.CreateInstance(typeof(T)));
    }
}

//內部嵌套類,通過構造函數對其字段賦值
private class Boxed
{
    internal T value;
    internal Boxed(T value)
    {
this.value = value;
    }
}
    }

自定義帶構造函數的類。

    public class Big
    {
public int ID { get; set; }
public Big(int id)
{
    this.ID = id;
}
    }

自定義創(chuàng)建對象實例的工廠類。

    public class BigFactory
    {
public static Big Build()
{
    return new Big(10);
}
    }

客戶端調用。

    class Program
    {
static void Main(string[] args)
{
    MyLazy<Big> temp = new MyLazy<Big>(() => BigFactory.Build());
    Console.WriteLine(temp.Value.ID);
    Console.ReadKey();
}
    }

延遲加載的本質大致是:

  • 由延遲加載類的內部嵌套類產生對象實例
  • 再通過延遲加載類的某個屬性來延遲獲取對象實例,而對象實例是通過委托等方式創(chuàng)建的

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對的支持。如果你想了解更多相關內容請查看下面相關鏈接

標簽: ASP.NET
相關文章:
主站蜘蛛池模板: 三级国产精品 | 日韩中文字幕在线免费观看 | 国产偷怕自拍 | 一级做人爱a视频正版免费 一级做性色a爱片久久片 | 欧美成人免费高清网站 | 中国美女隐私无遮挡免费视频 | 国产一区二区三区免费 | 草草影院www色极品欧美 | 草草影院ccyy国产日本欧美 | 97成人精品视频在线播放 | 97在线视频免费观看 | 在线观看中文字幕一区 | 日韩欧美毛片免费看播放 | 一区在线观看 | 成人一级片 | 国产高清三级 | 久久99国产亚洲高清观看首页 | 黄网在线视频 | 国内精品视频九九九九 | 日韩一区国产二区欧美三区 | 欧美综合自拍亚洲综合百度 | 在线观看精品国产 | 日本天堂网址 | 狠久久 | 欧美韩国xxx| 黄色a∨ | 久草三级 | 91青草久久久久久清纯 | 亚洲高清视频在线观看 | 一级aaa毛片| 欧美日本一区 | 国产高清成人mv在线观看 | 亚洲视频2 | 久久99热精品免费观看k影院 | 日本理论片午夜论片 | 午夜影院免费体验 | 欧美精品在线免费观看 | 久久99爱视频| 在线亚洲精品国产成人二区 | 亚洲经典在线观看 | 欧美日韩一日韩一线不卡 |