深入.NET Framework 4.0 关于Lazy的点滴

在微软发布的.NET Framework 4.0的Beta 2版本中,其又给我们带来了很多新东西,由于不知道正式版与之前的版本是否有过改进,我们只在这里来单纯地谈谈在.NET Framework 4.0中关于Lazy的实现。

创新互联公司专注于沧县企业网站建设,响应式网站开发,商城网站定制开发。沧县网站建设公司,为沧县等地区提供建站服务。全流程按需网站开发,专业设计,全程项目跟踪,创新互联公司专业和态度为您提供的服务

1.Lazy概述

我们也许会遇到这样一种情况,我们有一个大家伙(大对象)需要创建,那么这个对象的创建时需要较长的时间,同时也需要在托管堆上分配较多的空间。那么在.NET Framework 4.0中提供了这样一个很聪明的方式:Lazy(我们可以称之为懒对象)。当然,在之前,很多人也曾对其进行过自己的实现,那么我们在这里就可以把Lazy的作用总结为一句话:按需延迟加载。

2.Lazy的使用

了解了Lazy的作用,让我们就来看下Lazy如何应用:

 
 
 
  1. classProgram  
  2. {  
  3. staticvoidMain(string[]args)  
  4. {  
  5. LazylazyObject=newLazy();  
  6. Console.WriteLine(lazyObject.IsValueCreated);  
  7. lazyObject.Value.Test();  
  8. Console.WriteLine(lazyObject.IsValueCreated);  
  9. }  
  10. }  
  11.  
  12. [Serializable]  
  13. classLarge  
  14. {  
  15. publicLarge(){}  
  16. publicvoidTest()  
  17. {  
  18. Console.WriteLine("Test");  
  19. }  

这个例子很简单,也是Lazy最基本,也是最常用的应用方式。

3.实现自己的Lazy

在.NET Framework 4.0之前,大对象就是存在的,那么对于一个大型系统而言,怎么样对付一个大对象呢。在我看来有两点:延迟加载和即时清理。前者解决创建问题,后者解决回收问题,那么在来看Lazy的.NET Framework实现之前,我们先来自己实现一个简单的Lazy吧。

 
 
 
  1. classMyLazywhereT:new()  
  2. {  
  3. privateTvalue;  
  4. privateboolisLoaded;  
  5. publicMyLazy()  
  6. {  
  7. isLoaded=false;  
  8. }  
  9. publicTValue  
  10. {  
  11. get  
  12. {  
  13. if(!isLoaded)  
  14. {  
  15. value=newT();  
  16. isLoaded=true;  
  17. }  
  18. returnvalue;  
  19. }  
  20. }  

这应该是最简单版本的Lazy了,没有线程安全检测,其实什么都没有,只有着访问时创建真实对象,可是对于我们一般的应用来说也许就已经足够了。 #p#

4.Lazy的.NET Framework实现

原本还想解释下代码的,可是太多了,就写些主要吧,其实.NET Framework和上面的实现大同小异,有两点主要的不同:

A.引入了Boxed内部类:

 
 
 
  1. [Serializable]  
  2. privateclassBoxed  
  3. {  
  4. //Fields  
  5. internalTm_value;  
  6.  
  7. //Methods  
  8. [TargetedPatchingOptOut("PerformancecriticaltoinlinethistypeofmethodacrossNGenimageboundaries")]  
  9. internalBoxed(Tvalue)  
  10. {  
  11. this.m_value=value;  
  12. }  

该内部类取代了我在上面实现中的泛型约束,使之更通用,但是我们也应该注意到,如果T为结构体,那么由于T很大,所以装箱拆箱反而也许是个更耗费效率的事情,因此,个人建议,对值类型慎用Lazy

B.线程安全的控制

在线程安全的控制选项中,.NET Framework为我们提供了这样的枚举选项:

 
 
 
  1. publicenumLazyThreadSafetyMode  
  2. {  
  3. None,  
  4. PublicationOnly,  
  5. ExecutionAndPublication  

不做多余解释,关于这三者的具体意思,MSDN中已经说的很清楚了,可参加这里,里面的代码比较麻烦,就不多说了。

5.完善的大对象解决方案

在Anytao文章的回复中提到了一点是:Lazy+WeakReference才是实现一个大对象的完整解决之道,一个按需加载,一个不定清理,加到一起才完美。

本文转自飞林沙的博客,

原文地址:http://www.cnblogs.com/kym/archive/2010/02/21/1670226.html

【编辑推荐】

  1. .NET Framework 4.0功能特点详细讲解
  2. 全面解读.Net Framework源码调试详细步骤
  3. .Net Framework托管问题详解
  4. .Net Framework ping方法实现技巧讲解
  5. .Net Framework数组相关操作技巧分享

网页名称:深入.NET Framework 4.0 关于Lazy的点滴
转载来于:http://www.csdahua.cn/qtweb/news29/84179.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网