• <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 閱讀(190) 評論(0)  編輯 收藏 引用
             
            Copyright © HAOSOLA Powered by: 博客園 模板提供:滬江博客
            PK10開獎 PK10開獎
            A级毛片无码久久精品免费| 一级做a爰片久久毛片毛片| 91精品国产综合久久久久久| 久久精品国产99久久无毒不卡| 91精品国产高清91久久久久久| 久久久国产精品网站| 亚洲精品tv久久久久久久久久| 亚洲AV无码久久精品色欲| 国产欧美久久一区二区| 久久久久亚洲精品中文字幕 | 久久精品国产亚洲Aⅴ香蕉| 亚洲成av人片不卡无码久久| 久久AV高清无码| 日日狠狠久久偷偷色综合0| 国产精品久久网| 国产精品久久久久久五月尺| 中文字幕一区二区三区久久网站| 色婷婷综合久久久久中文字幕| 97精品久久天干天天天按摩| 国产精品美女久久福利网站| 久久99精品久久久久久野外| 精品永久久福利一区二区| 漂亮人妻被中出中文字幕久久| 国产女人aaa级久久久级| 久久99热只有频精品8| 囯产精品久久久久久久久蜜桃| 韩国三级中文字幕hd久久精品| 久久亚洲AV成人出白浆无码国产| 亚洲精品乱码久久久久久不卡| 国产精品伊人久久伊人电影| 国产精品美女久久久久网| 久久亚洲AV成人无码国产| 色偷偷久久一区二区三区| 久久综合久久美利坚合众国| 欧美久久综合九色综合| 久久精品国产精品亚洲人人| 国产精品成人99久久久久| 99精品久久久久久久婷婷| 亚洲狠狠久久综合一区77777 | 久久精品9988| 99久久国产亚洲高清观看2024|