.NET平台开源项目速览今天介绍一款小巧强大的对象比较组件。可以更详细的获取2个对象的差别,并记录具体差别,比较过程和要求可以灵活配置。

.NET开源目录:【目录】本博客其他.NET开源项目文章目录

本文地址:.NET平台开源项目速览(2)Compare .NET Objects对象比较组件

1.Compare .NET Objects介绍

Compare .NET Objects组件是.NET平台用于深入比较2个.NET对象的开源组件,一直在更新,主要功能如名字所示就是深入比较2个.NET对象,是否相等或者是否有差异。可能很多.NET对象实现了一些.NET自带的接口可以直接进行比较,但是这个组件比较的范围和功能更加广泛。例如:

可以比较默认的子节点;可以比较结构体;

可以比较IList对象;可以比较单维或者多维的数组对象;

可以比较枚举类型;可以比较IDictionary对象;

可以比较数据集,数据表,字典等等;

可以比较私有字段或者属性等等。。。。。。。。

Compare .NET Objects支持.NET 3.5及更高版本,同时也支持 Silverlight 5+, Windows Phone 8+, Windows RT 8+, Xamarin iOS, and Xamarin Android等环境。

还有很多,不一一列举,可以去官网详细了解。我们重点放在它的基本使用上面,本文就用几个例子带你走近它的世界。虽然简单,但更多复杂的功能可能会用于不同的业务场景,也许是你要的哦。。。该组件唯一的缺点是案例和文档不全面,所以我研究了一下用法,把常规的一些用法代码敲出来,给大家分享一下吧。

官方网站:http://comparenetobjects.codeplex.com/

    NuGet Package:http://www.nuget.org/packages/CompareNETObjects

2. Compare .NET Objects注意事项

在更好的使用Compare .NET Objects之前,需要搞清楚以下几个注意事项,可以让你走不少弯路,这几个要点也是翻译的官方网站的内容:

1.考虑到性能因素,Compare .NET Objects默认仅仅是检测第一个差异(就可以确认不是同一个对象),如果要比较多个不同点,需要手动设置Config.MaxDifferences到你需要的不同点数量的最大值;

2.在比较完成之后,对象差异不同点在Differences 列表 或者从DifferencesString 属性中获取;

3.默认情况下,是进行深度比较,如果只需呀执行浅比较,需要手动设置CompareChildren =false;

4.默认情况下,私有属性和私有字段是不比较的,如果需要进行比较,在比较之前要设置Config.ComparePrivateProperties 和Config.ComparePrivateFields 为true;

5.默认情况下,如果比较的2个对象的类型不同,是会抛出异常的,如果需要忽略这个因素,需要设置Config.IgnoreObjectTypes=true;

可见该组件的功能不仅完善,而且相对灵活,把你想要的和不想要的都灵活进行了考虑,通过设置不同的开关进行比较。

3.一个简单的使用案例

为了使得下面的源码介绍更清晰,先看一个简单使用的Demo,理解完Demo后,我们再反过来深入的介绍比较过程中的三大核心对象。理解了这三大核心对象,整个组件的逻辑和使用也基本清楚了。

3.1 首先定义一个Person类型

为了简单的比较,我们定义1个Person类型,包括名称,年龄和创建日期3个属性。如下面代码:

  1. public class Person
  2. {
  3. public String Name { get; set; }
  4. public Int32 Age { get; set; }
  5. public DateTime DateCreated { get; set; }
  6. }

3.2 比较测试Demo

首先要引用Compare-NET-Objects的dll,添加之后,要在Demo中添加命名空间的引用:

  1. using KellermanSoftware.CompareNetObjects;

接下来就看核心的使用过程,看代码注释:

  1. //创建比较对象的类型
  2. CompareLogic compareLogic = new CompareLogic();
  3.  
  4. //创建2个不同的Person类型
  5. Person person1 = new Person();
  6. person1.DateCreated = DateTime.Now;
  7. person1.Name = "Jorn";
  8. person1.Age = 25;
  9.  
  10. Person person2 = new Person();
  11. person2.Name = "Greg";
  12. person2.DateCreated = DateTime.Now;
  13. person2.Age = 22;
  14.  
  15. //设置比较对象的配置文件,最大不同点为3
  16. compareLogic.Config.MaxDifferences = 3;            
  17.  
  18. //获取比较结果,使用Compare方法
  19. ComparisonResult result = compareLogic.Compare(person1, person2);
  20.  
  21. //如果不相等,输出不同信息字符串
  22. if (!result.AreEqual)
  23. Console.WriteLine(result.DifferencesString);

如上面案例所示,整个过程有3个核心的相关对象和要点:

  1. CompareLogic对象的初始化;

  2. CompareLogic的配置设置的使用;实际上是ComparisonConfig类的设置

  3. 直接获取结果,并输出不同信息,实际是ComparisonResult的使用。

    上面只是一个简单的案例,要想深入了解使用,还得看看这3个主要对象的作用。

4.三大核心对象介绍

根据第3节的例子和过程,本节介绍3个核心类型的结构,在使用前搞懂他们的结构,可以更快的使用。由于本组件暂时没有提供帮助文档,所以我将这3个核心类的注释进行了翻译,并根据文章的注释手动制作一份CHM格式的帮助文档。

4.1 CompareLogic比较逻辑类

CompareLogic就是比较对象主要对象。它只包括2个核心的东西:

  1. 就是配置属性Config,这是个进行比较前最重要的设置,同时在CompareLogic初始化时,也可以使用ComparisonConfig传递参数进行初始化,这样就可以更简单,在某些情况下,不需要重复设置。采用统一的配置就可以了。如下面是的部分源代码:

    1. public class CompareLogic : ICompareLogic
    2. {
    3. /// <summary>默认的比较设置文件</summary>
    4. public ComparisonConfig Config { get; set; }
    5.  
    6. /// <summary>默认构造函数</summary>
    7. public CompareLogic()
    8. {
    9. Config = new ComparisonConfig();
    10. }
    11.  
    12. /// <summary>使用外部的比较设置对象来进行初始化</summary>
    13. /// <param name="config">外部设置对象</param>
    14. public CompareLogic(ComparisonConfig config)
    15. {
    16. Config = config;
    17. }
    18. ..........
    19. }
  2. 比较方法。返回一个ComparisonResult对象,这里设计到核心的比较方法的过程,就不追究了。

    所以上述Config属性我们在执行比较方法前,需要根据自己的需求进行设置,比如设置最大的不同数目等等。。比较方法很简单,核心在与返回的类型,接下来继续看。

4.2 ComparisonConfig比较配置类

比较配置类,在CompareLogic是作为一个属性,可以在程序中比较前进行设置的。其核心方法就是配置项目,例如,我将其核心代码贴出来,看一下,就一目了然了,这个组件要实现的不同条件下进行比较的效果和功能,就是靠这个配置来进行的。

  1. /// <summary>
  2. /// 时间日期类型不同(间隔)的最大毫秒数,默认为0:
  3. /// 意思就是比较2个时间对象,差别在这个值以下,就认为是相同的,类似Double处理相等时的精度
  4. /// </summary>
  5. public int MaxMillisecondsDateDifference { get; set; }
  6.  
  7. /// <summary>结构体比较的最大深度(比较子节点),默认为2</summary>
  8. public int MaxStructDepth { get; set; }
  9.  
  10. /// <summary>如果为true,遇到未知的对象类型时,将忽略,而不是直接抛出异常,默认为false,也就是抛出异常</summary>
  11. public bool IgnoreUnknownObjectTypes { get; set; }
  12.  
  13. /// <summary>如果为true,将跳过无效的索引。默认为false</summary>
  14. public bool SkipInvalidIndexers { get; set; }
  15.  
  16. /// <summary>在每个阶段比较后都显示记录,默认为false.这在调试很具有很深子节点的对象时非常有用</summary>
  17. public bool ShowBreadcrumb { get; set; }
  18.  
  19. /// <summary>比较中需要忽略的类型列表.默认比较多有的类型</summary>
  20. public List<Type> ClassTypesToIgnore { get; set; }
  21.  
  22. /// <summary>只需要比较的类型列表。默认是比较多有类型,如果设置这个列表,那将只比较这个列表中的类型</summary>
  23. public List<Type> ClassTypesToInclude { get; set; }
  24.  
  25. /// <summary>比较期间需要忽略的数据表名称,或者表列名称,属性,或者字段。对大小写敏感</summary>
  26. /// <example>MembersToIgnore.Add("CreditCardNumber")</example>
  27. public List<string> MembersToIgnore { get; set; }
  28.  
  29. /// <summary>只比较列表中的名称,如数据表,列名称,属性或者字段,大小写敏感。和上面的类型处理类似。</summary>
  30. /// <example>MembersToInclude.Add("FirstName")</example>
  31. public List<string> MembersToInclude { get; set; }
  32. ...................

其他还有很多,详细看我提供的源代码。我对几个核心类进行了翻译,可以更快的进行使用和理解。

4.3 ComparisonResult比较结果类

比较结果也很重要,如果只是想简单的返回相等和不相等其实太容易了,这也是这个功能组件不一样的地方。它将结果和不同点都进行了考虑,可以在比较完成后查询到不同点这个对象,或者直接 的字符串,并将不同点的值也表现出来。使用它,主要注意3个 属性:

  1. /// <summary>比较发现的不同点</summary>
  2. public List<Difference> Differences { get; set; }
  3. /// <summary>比较不同点,以字符串描述</summary>
  4. public string DifferencesString{get ;}
  5. /// <summary>如果相同则返回true</summary>
  6. public bool AreEqual{get ;}

这在Demo代码中也有用到。调试的时候,大家看一看,如下图所示:

    今天的内容就介绍到此。

5.资源

  你可以从官方网站:http://comparenetobjects.codeplex.com/下载源代码。

  我文中的演示Demo及项目的翻译部分,这里也提供一个下载,日期是在2015-5-22下载的基础上修改的。

  我的下载地址:CompareNetObjects-150525.rar

  我手动制作了一个部分翻译后的组件帮助文档,如下图:

下载地址:Compare.NET组件CHM.rar ,童鞋们,下载后别忘记点赞哦。。。

.NET平台开源项目速览(2)Compare .NET Objects对象比较组件的更多相关文章

  1. .NET平台开源项目速览(14)最快的对象映射组件Tiny Mapper

    好久没有写文章,工作甚忙,但每日还是关注.NET领域的开源项目.五一休息,放松了一下之后,今天就给大家介绍一个轻量级的对象映射工具Tiny Mapper:号称是.NET平台最快的对象映射组件.那就一起 ...

  2. .NET平台开源项目速览(5)深入使用与扩展SharpConfig组件

    上个月在文章:这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧  和 .NET平台开源项目速览(1)SharpConfig配置文件读写组件 中都提到了SharpConfig组件,简单轻量级 ...

  3. .NET平台开源项目速览(4).NET文档生成工具ADB及使用

    很久以前就使用ADB这个工具来生成项目的帮助文档.功能强大,在学习一些开源项目的过程中,官方没有提供CHM帮助文档,所以为了快速的了解项目结构和注释.就生成文档来自己看,非常好用.这也是一个学习方法吧 ...

  4. .NET平台开源项目速览-最快的对象映射组件Tiny Mapper之项目实践

    心情小札:近期换了工作,苦逼于22:00后下班,房间一篇狼藉~ 小翠鄙视到:"你就适合生活在垃圾堆中!!!" 晚上浏览博客园 看到一篇非常实用的博客:.NET平台开源项目速览(14 ...

  5. .NET平台开源项目速览(17)FluentConsole让你的控制台酷起来

    从该系列的第一篇文章 .NET平台开源项目速览(1)SharpConfig配置文件读写组件 开始,不知不觉已经到第17篇了.每一次我们都是介绍一个小巧甚至微不足道的.NET平台的开源软件,或者学习,或 ...

  6. .NET平台开源项目速览(15)文档数据库RavenDB-介绍与初体验

    不知不觉,“.NET平台开源项目速览“系列文章已经15篇了,每一篇都非常受欢迎,可能技术水平不高,但足够入门了.虽然工作很忙,但还是会抽空把自己知道的,已经平时遇到的好的开源项目分享出来.今天就给大家 ...

  7. .NET平台开源项目速览(13)机器学习组件Accord.NET框架功能介绍

    Accord.NET Framework是在AForge.NET项目的基础上封装和进一步开发而来.因为AForge.NET更注重与一些底层和广度,而Accord.NET Framework更注重与机器 ...

  8. .NET平台开源项目速览(1)SharpConfig配置文件读写组件

    在.NET平台日常开发中,读取配置文件是一个很常见的需求.以前都是使用System.Configuration.ConfigurationSettings来操作,这个说实话,搞起来比较费劲.不知道大家 ...

  9. .NET平台开源项目速览(12)哈希算法集合类库HashLib

    .NET的System.Security.Cryptography命名空间本身是提供加密服务,散列函数,对称与非对称加密算法等功能.实际上,大部分情况下已经满足了需求,而且.NET实现的都是目前国际上 ...

随机推荐

  1. 在安装AndroidStudio时产生的问题

    JDK安装完毕,环境变量也配置完了,AndroidStudio安装完了,其中SDK使用了自己下载好的包. 但是第一次打开AndroidStudio的时候出现了错误: java.lang.Runtime ...

  2. 【EntityFramework Core】实体实例化注入

    由于逻辑需要,我希望能在EF Core实例化实体时,拿到实体并执行相关代码,所以我就研究了一番EF Core,得到以下方法. 1.创建实体初始化类,继承EntityMaterializerSource ...

  3. lua的C库

    在云风的ejoy2d里是没有dll和so之类的东西的, 所有的C扩展都是类似这样写的: int ejoy2d_shader(lua_State *L) {      luaL_Reg l[] = { ...

  4. 使用canal分析binlog(二) canal源码分析

    在能够跑通example后有几个疑问 1. canal的server端对于已经读取的binlog,client已经ack的position,是否持久化,保存在哪里 2. 即使不启动zookeeper, ...

  5. Web API 之CRUD

    注:例子来自微软Web API官网(https://www.asp.net/web-api/overview/data/using-web-api-with-entity-framework/part ...

  6. node-schedule定时任务

    https://github.com/node-schedule/node-schedule npm install node-schedule * * * * * * ┬ ┬ ┬ ┬ ┬ ┬ │ │ ...

  7. 【Telerik】<telerik:RadComboBox>导出列表数据

    近来在做项目,做到导出功能.使用<telerik:RadComboBox>的下拉框来实现导出部分或导出所有数据的功能.

  8. 【Beta】Daily Scrum Meeting第四次

    1.任务进度 学号 已完成 接下去要做 502 修复和完善任务列表界面:将几个数据库操作封装起来 登陆时将返回的个人信息更新到本地数据库 509 创建报课表的API 给所有api添加注释:发布任务到服 ...

  9. 深入理解javascript系列(4):立即调用的函数表达式

    本文来自汤姆大叔 前言 大家学JavaScript的时候,经常遇到自执行匿名函数的代码,今天我们主要就来想想说一下自执行. 在详细了解这个之前,我们来谈了解一下“自执行”这个叫法,本文对这个功能的叫法 ...

  10. CharSequence cannot be resolved. It is indirectly referenced from required .class files

    最近在写项目的时候发现会莫名其妙的出现这个编译错误,网上查了下发现自己安装的是JDK1.8造成的 原因:JDK1.8版本现在还不稳定 解决方法:卸载JDK1.8,安装JDK1.7 扩展:发现安装JDK ...