• <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開獎
            中文字幕久久欲求不满| 色妞色综合久久夜夜| 久久精品国产精品亜洲毛片| 少妇被又大又粗又爽毛片久久黑人| 久久久久久国产a免费观看黄色大片| 久久国产欧美日韩精品免费| 国产精品一久久香蕉国产线看| 久久久黄片| 久久精品国产亚洲网站| 精品国产乱码久久久久软件| 97超级碰碰碰久久久久| 久久久精品人妻无码专区不卡| 久久中文骚妇内射| 7777精品伊人久久久大香线蕉| 久久亚洲国产午夜精品理论片| 中文字幕人妻色偷偷久久| 久久久艹| 狠狠久久综合| 久久天堂电影网| 久久久亚洲欧洲日产国码二区| 亚洲欧美成人久久综合中文网| 欧美777精品久久久久网| 亚洲AV日韩精品久久久久久| 久久人人超碰精品CAOPOREN | 久久香蕉一级毛片| 午夜久久久久久禁播电影| 思思久久99热只有频精品66| 久久久久国色AV免费看图片| 久久激情亚洲精品无码?V| 亚洲国产精品久久久久久| 色综合色天天久久婷婷基地| 久久免费视频观看| 国产精品99久久久久久www| 久久亚洲精品中文字幕三区| 国产精品久久影院| 国产精品成人无码久久久久久 | 日产久久强奸免费的看| 久久综合伊人77777麻豆| 女同久久| 亚洲精品高清国产一线久久| 无遮挡粉嫩小泬久久久久久久|