• <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++
            日歷
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345
            統(tǒng)計
            • 隨筆 - 92
            • 文章 - 4
            • 評論 - 4
            • 引用 - 0

            導航

            常用鏈接

            留言簿

            隨筆檔案

            文章檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

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

            先來看一下在Framework4.0中如何實現(xiàn)延遲加載。

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

          1. ///這行代碼表明:要創(chuàng)建一個延遲加載的字符串對象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屬性來確定對象是否已創(chuàng)建,通過Value屬性來獲取當前對象的值。

             

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

             

            下面經(jīng)出完整代碼,以供測試:

             

          15. class Program  
          16. {  
          17. static void Main(string[] args)  
          18. {  
          19. ///這行代碼表明:要創(chuàng)建一個延遲加載的字符串對象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. }   

             

            運行結果如圖示:

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

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

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

          75. posted on 2011-07-11 20:36 HAOSOLA 閱讀(192) 評論(0)  編輯 收藏 引用
             
            Copyright © HAOSOLA Powered by: 博客園 模板提供:滬江博客
            PK10開獎 PK10開獎
            亚洲午夜无码久久久久| 熟妇人妻久久中文字幕| 色狠狠久久综合网| 性欧美大战久久久久久久久| 久久免费小视频| 久久有码中文字幕| 久久香蕉超碰97国产精品| 久久国产精品久久久| 亚洲国产日韩欧美综合久久| 91视频国产91久久久| 亚洲精品国精品久久99热| a级成人毛片久久| 久久精品国产免费观看| 久久久久久免费一区二区三区| 久久久久久曰本AV免费免费| 99久久精品国产综合一区| 国产精品一久久香蕉国产线看观看| 免费一级欧美大片久久网| 国产亚洲综合久久系列| 久久精品成人欧美大片| 久久精品无码一区二区三区日韩| 无码久久精品国产亚洲Av影片| 亚洲精品久久久www| 国产精品热久久毛片| 久久久久国产精品| 国产精品久久久天天影视| 久久丫精品国产亚洲av不卡 | 亚洲女久久久噜噜噜熟女| 国产高潮国产高潮久久久91| 青青青国产成人久久111网站| 久久久久久夜精品精品免费啦| 少妇熟女久久综合网色欲| 最新久久免费视频| 久久国产精品无| 久久天天躁狠狠躁夜夜不卡| 久久久国产亚洲精品| 免费精品国产日韩热久久| 精品熟女少妇AV免费久久| 亚洲国产精品无码久久一线| 亚洲综合熟女久久久30p| 久久天天躁狠狠躁夜夜96流白浆 |