写点什么

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

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

关注

评论

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

揭秘,实时比赛统计模块如何集成开发到体育直播平台

软件开发-梦幻运营部

如何评估迷因币的成功潜力?

区块链软件开发推广运营

交易所开发 链游开发 公链开发 链游开发dapp开发 NFFT开发

并发编程/Actor模型设计为高并发项目提供基础模型(设计篇)

肖哥弹架构

Java 并发编程 高并发

ROS机器视觉入门:从基础到人脸识别与目标检测

梦笔生花

机器视觉 ROS

实操案例|TinyVue树表+动态行合并

OpenTiny社区

开源 前端 组件库 OpenTiny TinyVue

官方带队实测,阶梯式解锁飞桨框架3.0能力新特性,轻松上手!

飞桨PaddlePaddle

百度 飞桨AI

Gemini 发布 iOS app,Live 语音聊天免费用;微信公众号上线 AI 音色克隆功能丨 RTE 开发者日报

声网

JNPF低代码开发平台赋能数智化转型探索及趋势分析

快乐非自愿限量之名

低代码

鲲鹏原生赋能浩瀚深度,网络数据可视化处理更加高效

Geek_2d6073

火山引擎与东风Honda,为用户创造了个驾乘“搭子”

新消费日报

淘宝/天猫商品详情API返回值深度剖析与实战运用:聚焦taobao.item_get_desc

代码忍者

API 接口 pinduoduo API

如何使用Python开发1688商品详情API接口?

科普小能手

API 1688 Python开发 API 接口 1688商品详情接口

Go协程池开源库及示例用法

baiyutang

Go golang 编程 云原生

DeFi 市场收益疲软?Astherus 或成用户捕获收益的最佳管道

股市老人

税友:基于鲲鹏原生开发税务行业应用,引领智慧税务

Geek_2d6073

从503错误到无忧请求:自动重试与代理切换的完美实现

LLLibra146

Python requests 自动重试 切换代理

Spring Cloud Ribbon 实现“负载均衡”的详细配置说明

快乐非自愿限量之名

Spring Boot

华为之泉,涌入开源事业的大江大河

脑极体

AI 软件

精准测试如何落地

霍格沃兹测试开发学社

鸿蒙开发Hvigor任务简介

龙儿筝

访问海外网站的网络工具: SD-WAN海外专线

Ogcloud

SD-WAN SD-WAN组网 SD-WAN国际专线 海外网络专线 跨国网络专线

浅谈DNS递归解析和迭代解析之间的区别

国科云

域名解析 DNS解析

一键自动生成ppt的AI工具!这5款不容错过!

职场工具箱

人工智能 PPT 办公软件 AIGC AI生成PPT

Carft - 一款小众而不简单的笔记软件

JAVGO

笔记软件

多分支组网解决方案:SD-WAN

Ogcloud

SD-WAN 企业组网 SD-WAN组网 SD-WAN服务商 SDWAN

想管理好团队?一定要三“靠”三“不靠”

敏捷开发

管理 团队建设 企业管理 团队协同

股票API接口:功能对比与应用场景

幂简集成

API 股票

Java实现随机抽奖的方法有哪些

不在线第一只蜗牛

Java Python

wifi7 IPQ5322 and QCN9274/QCN6274 Chip Solutions Detailed Overview and Application Prospects

wifi6-yiyi

WiFi7 wap3

如何做好客户管理?主要内容介绍

爱吃小舅的鱼

客户管理

用通义灵码,从 0 开始打造一个完整APP,无需编程经验就可以完成

阿里云云效

阿里云 云原生

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