写点什么

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

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

关注

评论

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

亚马逊云科技携手 Vodafone Business 向欧洲企业推广边缘计算

亚马逊云科技 (Amazon Web Services)

百分点大数据技术团队:ClickHouse国家级项目性能优化实践

百分点科技技术团队

模块二作业

VE

架构实战营

高阶的产品经理是什么样的?

石云升

产品经理 职场经验 7月日更

北鲲云超算:以HPC解决方案助力生命科学领域研究发展

北鲲云

【得物技术】零拷贝

得物技术

io 网络 零拷贝 流程 传输

我佛了!花重金求来的并发编程笔记,颠覆了我以往“正确“的认知

Java 编程 程序员

便捷赔付,自在出行!亚马逊云科技助力车险业务因“云”而变

亚马逊云科技 (Amazon Web Services)

Python OpenCV 基于图像边缘提取的轮廓发现函数

梦想橡皮擦

7月日更

架构实战营模块二作业

Clarke

架构实战营

Python 实战(五)| 字符串

一个优秀的废人

极光开发者周刊【No.0716】

极光JIGUANG

网易云信线上万人连麦技术大揭秘

网易云信

网易 视频 音频技术

百分点数据科学实验室:智慧应急安全生产智能决策方案建设实践

百分点科技技术团队

phabricator + gitlab 强制code review

阿呆

gitlab Code Review phabricator

“低代码开发”与“传统IT开发”的区别是什么?

优秀

低代码

Magician 1.1.16 is released, the handler adopts annotation configuration

Magician网络编程包

Java nio

2021年6月券商App行情刷新及交易体验评测报告

博睿数据

博睿数据 博睿指数 券商App

智能合约DAPP系统开发技术搭建

薇電13242772558

区块链 智能合约

Magician 1.1.16 发布,handler采用注解配置

Magician网络编程包

Java 网络编程 nio

模块二作业:微信朋友圈高性能复杂度架构设计

Felix

第四周作业-知识星球加入星球的用例文档

小夏

产品经理训练营 邱岳

Lamda(拉姆达)表达式演化过程

叫练

jdk8 JDK1.8新特性

博睿数据亮相2021中国互联网大会,践行数字政府新路径

博睿数据

博睿数据 数据链DNA

阿里“保姆级”教程,这份SpringBoot应用到实战手册,满满的精华

Java架构师迁哥

利用亚马逊云科技的 Cloudify 实施 5G 网络切片

亚马逊云科技 (Amazon Web Services)

Web UI自动化的设计和实践

GrowingIO技术专栏

B 站崩了:事情不大,影响不小

Java架构师迁哥

作为程序员,遇到问题时你的解决手段是什么?

阿杰

程序员

5分钟速读之Rust权威指南(四十二)高级函数

wzx

rust

捕货拼团软件系统开发详情

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