写点什么

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:251076
用户头像

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

关注

评论

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

基于rsync实现海量文件高速传输的解决方案

镭速

《三体》问题

蓬蒿

CPU 寄存器 延时

一文读懂Js中的this指向

hellocoder2029

JavaScript 前端

你需要知道的webpack高频面试题

Geek_02d948

JavaScript 前端

2023秋招前端面试必会的面试题

Geek_02d948

JavaScript 前端

深入nodejs的event-loop

coder2028

JavaScript 前端

2023秋招前端面试必会的面试题

coder2028

JavaScript 前端

认识一下,我们是应用社交「幕后大佬」 IM 家族

融云 RongCloud

即时通讯 IM

NCCL源码解析①:初始化及ncclUniqueId的产生

OneFlow

人工智能 深度学习

vue的几个提效技巧

yyds2026

Vue 前端

vue实战中的一些小技巧

yyds2026

Vue 前端

SpringBoot中事件与通知

石臻臻的杂货铺

spring springboot

前端常考面试题整理

hellocoder2029

JavaScript 前端

一文彻底搞懂前端缓存机制

hellocoder2029

JavaScript 前端

拿到大厂前端offer的前端开发是怎么回答面试题的

hellocoder2029

JavaScript 前端

前端必会vue面试题(必备)

yyds2026

Vue 前端

彻底搞懂nodejs事件循环

coder2028

JavaScript 前端

通过微信小程序体验阿里云IoT物联网平台——设备接入类

阿里云AIoT

物联网

深入理解 Taier:MR on Yarn 的实现原理

袋鼠云数栈

hadoop

Stage模型深入解读

HarmonyOS开发者

HarmonyOS

3.15 数据库吐槽大会

NineData

数据库 mongodb 云计算 程序员 图数据库

一文彻底读懂webpack常用配置

Geek_02d948

JavaScript 前端

前端经典面试题(有答案)

coder2028

JavaScript 前端

前端常考vue面试题(必备)

yyds2026

Vue 前端

Nautilus Chain 现已推出测试网“Triton ”,有哪些潜在的机会?

西柚子

ArkUI中的线程和看门狗机制

OpenHarmony开发者

OpenHarmony

美团前端高频面试题集锦

Geek_02d948

JavaScript 前端

LeetCode题解:137. 只出现一次的数字 II,哈希表,JavaScript,详细注释

Lee Chen

JavaScript LeetCode

21天吃透这套字节面试题后,我成功跳槽进了字节,税后25K

做梦都在改BUG

Java 数据结构 面试 算法

如何评估某活动带来的大盘增量 | 得物技术

得物技术

AI 数据

【记】滑动拼图验证码在搜索中的作用

宙哈哈

Python html 验证码

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