AI 时代下组织如何快速变革?如何提升全员 AI 技能?戳> 了解详情
写点什么

Greg Finzer 谈 Compare .NET Objects

  • 2013-11-25
  • 本文字数:1782 字

    阅读完需:约 6 分钟

编写对象比较的代码可能非常枯燥,特别是在处理大对象或者深度图的时候。在类变化的时候错误通常会偷偷的溜进去。减少潜在错误的一种方式是依赖于类库,例如 Greg Finzer 的 Compare .NET Objects 。该类库为多达 1 万个对象的比较提供合理的性能。

InfoQ:启发你创建 Compare .NET Objects 类库的第一件事是什么?

当 Microsoft 发布 Developer Tools for Windows Phone 7 的时候在 Windows Phone 7 社区中引发了非常强烈的抗议,因为 Microsoft 并没有提供一个数据库。而我个人认为这应该是一个非常好的为 Windows Phone 7 创建一个数据库的机会,因为并没有竞争对手并且有清晰的需求。我过去一直想要创建一个对象数据库从而绕开数年来处理 ORM 的痛苦。那时候 Windows Phone 7 允许的应用程序数据最大才是 90MB。我们需要在尽可能最小的空间中存储数据,甚至比 JSON 还小。我发现.NET Framework for Windows Phone 7 早期并没有可用的二进制序列化器。在 CodePlex 上有一个开源的二进制序列化器: https://slserializelzo.codeplex.com/ 。 我注册并成为了那个项目的测试员。为了验证序列化 / 反序列化我创建了 Compare .NET Objects,而不是手工的编写几百个反射测试。最后,创建 Ninja Database Pro 的时候我们并没有利用 CodePlex 序列化类库。但是我们自己的二进制序列化器确实使用了 Compare .NET Objects 进行所有的集成测试。我将 Compare .NET Objects 剥离成了一个独立的开源项目,使它可以为开发者社区服务。

InfoQ:你还看见开发者按照其他的方式使用过你的类库么?

我认为 Compare .NET Objects 非常适合于编写验证 ORM 映射的集成测试。我为 Sogeti 工作。在过去的一年我在俄亥俄州航空办公室的一个项目上使用了 Compare .NET Objects 进行集成测试。在该项目上我们使用了 Compare .NET Objects 验证 Spring Framework .NET 映射。我还看见过其他开发人员使用 Compare .NET Objects 判断一个对象是否是脏对象需要被保存到数据库中,还有人使用它实现审计的目的,有人将它应用于 power shell 脚本中。

InfoQ:它支持所有其他的.NET 平台么,例如 Windows Phone、Windows Store?

在代码中有一个针对 Silverlight 的编译器常量,所以它应该可以在 Windows Phone 和 Silverlight 上使用。但是我现在并没有考虑让它兼容 Windows Store。最后,我计划实现几个独立的项目,为每一个不同的平台单独构建,类似于我在我们的商业产品中所做的事情那样。

InfoQ:Compare .NET Objects 中是否有一些现在没有但是你想要添加的内容?

尽管人们发 email 感谢我它是一个单独的类,但是我认为是时候将 Compare .NET Objects 重构为更多可维护的类了。在过去的几年中我一直在添加功能,现在它有很多坏的代码味道。它明显违反了 S.O.L.I.D. 设计原则,特别是 SRP。同时将所有的内容写到一个类中也带来了很多合并上的痛苦。我将在保持向后兼容性的同时添加一个线程安全的选项。

InfoQ:你发现了没有,反射的使用引发了性能问题?如果是这样,为了缓解它你现在做了什么?

如此之多的人在反射引发性能问题的事情上喋喋不休,但是我从来没有真正地看到有很大的影响。之前有一个项目客户端请求将 9000 个条目加载到 Web 页面上的一个下拉列表中,加载过程大约花费了 20 秒钟。我们使用了 NHibernate 从 Oracle 数据库中加载数据。NHibernate 就使用了反射。所以性能问题在哪里呢?数据库?NHibernate?Internet Explorer?都不是,性能问题是网络带宽。我们最终实现了一个 Ajax 自动完成下拉列表,它每次仅加载 20 个条目。如果你正在处理大量的对象,那么比较起来反射引发的担心最少。

我已经在 Compare .NET Objects 中添加了反射缓存,这样确实有助于提高性能。看看测试项目中的 CachingTest 就行了。在我的机器上,如果禁用反射缓存比较 1 万个对象要花费 319 毫秒,如果启用反射缓存则要花费 224 毫秒。我会说如果你一次性比较超过 1 万个对象,那么我不会使用 Compare .NET Objects。在那种情况下,我会为那些类重写 Equals 和 GetHashCode 方法。

InfoQ:你现在正在寻找志愿者为 Compare .NET Objects 工作么?

当然,我们有很多工作要做呢:

  • 将每一种类型的比较器重构为单独的类
  • 线程安全的配置和比较
  • 为每一个平台提供单独的项目:Mono、Silverlight、Windows Phone、Windows Store

查看英文原文 An Interview with Greg Finzer of Compare .NET Objects

2013-11-25 07:251173
用户头像

发布了 321 篇内容, 共 122.7 次阅读, 收获喜欢 19 次。

关注

评论

发布
暂无评论
发现更多内容

HCIE云计算--灾备

爱好编程进阶

Java 面试 后端开发

报告解读下载 | 首份《中国数据库行业分析报告》重磅发布!

墨天轮

数据库 国产数据库 达梦 polarDB gbase8a

TASKCTL 消息订阅参数设置说明

敏捷调度TASKCTL

DevOps 分布式 敏捷开发 ETL任务 自动化运维

叮咚!请查收来自一线数据科学家和大数据工程师的实战经验| IDP Meetup No.02 回顾

Baihai IDP

Python 大数据 AI 算法 数据科学

2021银四特惠:分享字节跳动(提前批

爱好编程进阶

Java 面试 后端开发

985应届进大厂,后端开发两年被裁,对前路迷茫的我

爱好编程进阶

Java 面试 后端开发

Alibaba最新出品Java面试手册,号称金九银十面试“完美日记

爱好编程进阶

Java 面试 后端开发

BS-GX-016基于SSM实现教材管理系统

爱好编程进阶

Java 面试 后端开发

Java8的这些集合骚操作,你掌握了嘛?

爱好编程进阶

Java 面试 后端开发

自主研发,自主可控,星环科技“魔方底座”全面升级!

星环科技

流程图太大? 来个流程收缩展开功能

相续心

前端 工作流 流程图 SOP

Dubbo如何处理业务异常,这个一定要知道哦!

爱好编程进阶

Java 面试 后端开发

Elasticsearch7

爱好编程进阶

Java 面试 后端开发

星环科技创始人孙元浩:数据连接一切,开启融合数据云时代

星环科技

Java学习路线图(如何快速学Java)

爱好编程进阶

Java 面试 后端开发

5 款最棒的 Vue 移动端 UI 组件库 - 特别针对国内使用场景推荐

蒋川

Vue

Java-8新特性:学习如何使用Lambda表达式(二

爱好编程进阶

Java 面试 后端开发

Java-String-对象,你真的了解了吗?

爱好编程进阶

Java 面试 后端开发

Docker下,两分钟极速体验Nacos配置中心

爱好编程进阶

Java 面试 后端开发

Java 线程池原理分析

爱好编程进阶

Java 面试 后端开发

2021年最新基于Spring Cloud的微服务架构分析

爱好编程进阶

Java 面试 后端开发

2021阿里技术官重磅推出“Java进阶必备宝典” 5大专题 6000字解析

爱好编程进阶

Java 面试 后端开发

Elasticsearch7(1)

爱好编程进阶

Java 面试 后端开发

ForkJoin实现分而治之

爱好编程进阶

Java 面试 后端开发

Github神作!2021Java秋招高级面试指南,吃透至少阿里P6

爱好编程进阶

Java 面试 后端开发

gRPC学习之六:gRPC-Gateway集成swagger

爱好编程进阶

Java 面试 后端开发

TiDB 6.0 的「元功能」:Placement Rules in SQL 是什么?

PingCAP

10年Java开发经验,超过500人面试阿里的同学,总结出这108道面试题

爱好编程进阶

Java 面试 后端开发

CAT客户端如何从Apollo中读取配置?

爱好编程进阶

Java 面试 后端开发

CDH+Kylin三部曲之三:Kylin官方demo

爱好编程进阶

Java 面试 后端开发

Java字符串转码

爱好编程进阶

Java 面试 后端开发

Greg Finzer谈Compare .NET Objects_.NET_Jonathan Allen_InfoQ精选文章