• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            C++分析研究  
            C++
            日歷
            <2011年7月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456
            統計
            • 隨筆 - 92
            • 文章 - 4
            • 評論 - 4
            • 引用 - 0

            導航

            常用鏈接

            留言簿

            隨筆檔案

            文章檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             
            延遲加載,亦稱延遲實例化,延遲初始化等,主要表達的思想是,把對象的創建將會延遲到使用時創建,而不是在對象實例化時創建對象,即用時才加載。這種方式有助于提高于應用程序的性能,避免浪費計算,節省內存的使用等。針對于這種做法,似乎稱之為即用即創建更為合適些。

            先來看一下在Framework4.0中如何實現延遲加載。

            Framework4.0提供了一個包裝類 Lazy,可以輕松的實現延遲加載。

          1. ///這行代碼表明:要創建一個延遲加載的字符串對象s  
          2. ///原型為LazyT> 對象名=new LazyT>(FunT>)  
          3. ///采用泛型委托進行構造,實例化此委托時要求必須是返回值T類型的方法  
          4. ///如在本例中,T為string,則TestLazy.GetString方法的返回值必須也是string類型  
          5. Lazystring> s = new Lazystring>(TestLazy.GetString); www.liuhebao.com     

             

            本例中TestLazy.GetString()方法如下示:

             

          6. public class TestLazy    
          7. {    
          8. public static string GetString()    
          9. {    
          10. return DateTime.Now.ToLongTimeString();    
          11. }   
          12. }    

             

            可以通過IsValueCreated屬性來確定對象是否已創建,通過Value屬性來獲取當前對象的值。

             

          13. Console.WriteLine(s.IsValueCreated);//返回False  
          14. Console.WriteLine(s.IsValueCreated);//返回True   

             

            下面經出完整代碼,以供測試:

             

          15. class Program  
          16. {  
          17. static void Main(string[] args)  
          18. {  
          19. ///這行代碼表明:要創建一個延遲加載的字符串對象s  
          20. ///原型為Lazy 對象名=new Lazy(Fun) www.yzyedu.com  
          21. ///采用泛型委托進行構造,實例化此委托時要求必須是返回值T類型的方法  
          22. ///如在本例中,T為string,則TestLazy.GetString方法的返回值必須也是string類型  
          23. Lazy s = new Lazy(TestLazy.GetString);  
          24. Console.WriteLine(s.IsValueCreated);//返回False  
          25. Console.WriteLine(s.IsValueCreated);//返回True  
          26. }  
          27. }  
          28. public class TestLazy  
          29. {  
          30. public static string GetString()  
          31. {  
          32. return DateTime.Now.ToLongTimeString();  
          33. }  
          34. }    

             

            下面再用一個例子,演示延遲加載:

            在這個例子中,使用了BlogUser對象,該對象包含多個Article對象,當加載BlogUser對象時,Article對象并不加載,當需要使用Article對象時,才加載。

             

          35. class Program  
          36. {  
          37. static void Main(string[] args)  
          38. {  
          39. BlogUser blogUser = new BlogUser(1);  
          40. Console.WriteLine("blogUser has been initialized");  
          41. {   
          42. Console.WriteLine(article.Title);}  
          43. }  
          44. }  
          45. public class BlogUser  
          46. {  
          47. public int Id { getprivate set; }  
          48. public Lazy> Articles { getprivate set; }  
          49. public BlogUser(int id) www.jokedu.com   
          50. {  
          51. this.Id = id;  
          52. Articles =new Lazy>(()=>ArticleServices.GetArticesByID(id));  
          53. Console.WriteLine("BlogUser Initializer");  
          54. }  
          55. }  
          56. public class Article  
          57. {  
          58. public int Id { getset; }  
          59. public string Title{get;set;}  
          60. public DateTime PublishDate { getset;}  
          61. public class ArticleServices  www.yzjxsp.com  
          62. {  
          63. public static List GetArticesByID(int blogUserID)  
          64. {  
          65. List articles = new List {  
          66. new Article{Id=1,Title="Lazy Load",PublishDate=DateTime.Parse("2011-4-20")},  
          67. new Article{Id=2,Title="Delegate",PublishDate=DateTime.Parse("2011-4-21")},  
          68. new Article{Id=3,Title="Event",PublishDate=DateTime.Parse("2011-4-22")},  
          69. new Article{Id=4,Title="Thread",PublishDate=DateTime.Parse("2011-4-23}  
          70. };  
          71. Console.WriteLine("Article Initalizer");  
          72. return articles;  
          73. }  
          74. }   

             

            運行結果如圖示:

            最后說一下,延遲加載主要應用場景:

            當創建一個對象的子對象開銷比較大時,而且有可能在程序中用不到這個子對象,那么可以考慮用延遲加載的方式來創建子對象。另外一種情況就是當程序一啟動時,需要創建多個對象,但僅有幾個對象需要立即使用,這樣就可以將一些不必要的初始化工作延遲到使用時,這樣可以非常有效的提高程序的啟動速度。

            這種技術在ORM框架得到了廣泛應用,也并非C#獨有的,比如Java里的Hibernate框架也使用了這一技術。

          75. posted on 2011-07-11 20:36 HAOSOLA 閱讀(192) 評論(0)  編輯 收藏 引用
             
            Copyright © HAOSOLA Powered by: 博客園 模板提供:滬江博客
            PK10開獎 PK10開獎
            亚洲综合熟女久久久30p| 高清免费久久午夜精品| 久久久久九九精品影院| 色婷婷噜噜久久国产精品12p| 国产精品成人精品久久久| 亚洲日本va午夜中文字幕久久| 亚洲人成无码久久电影网站| 精品久久一区二区三区| 狠狠色丁香久久婷婷综合五月| 久久人爽人人爽人人片AV| 久久天天躁狠狠躁夜夜躁2O2O| 久久精品国产只有精品66| 久久伊人亚洲AV无码网站| 国产美女久久久| 少妇熟女久久综合网色欲| 国内精品久久久久影院免费| 一97日本道伊人久久综合影院| 97久久久久人妻精品专区| 伊人久久成人成综合网222| 伊人久久大香线蕉精品| 天天爽天天狠久久久综合麻豆| 久久久精品人妻无码专区不卡| 久久精品水蜜桃av综合天堂| 一级做a爰片久久毛片毛片| 久久国产精品免费一区| 久久青草国产精品一区| 久久精品国产久精国产果冻传媒 | 久久精品国产精品亚洲| 香港aa三级久久三级| 欧美激情精品久久久久久| 狠狠综合久久综合88亚洲| 国产日产久久高清欧美一区| 精品久久人人爽天天玩人人妻| 天天综合久久一二三区| 婷婷久久综合九色综合九七| 久久播电影网| 一本久道久久综合狠狠躁AV| 午夜精品久久久内射近拍高清| 亚洲国产成人精品女人久久久 | 久久综合久久伊人| 久久精品女人天堂AV麻|