QCon北京「鸿蒙专场」火热来袭!即刻报名,与创新同行~ 了解详情
写点什么

IQueryable 对于 API 是个错误的选择吗?

  • 2012-04-11
  • 本文字数:546 字

    阅读完需:约 2 分钟

Mark Seemann 在他的一篇名为“ IQueryable 之紧耦合”的文章中建议不要在设计 API 时暴露 IQueryable 接口,并列出了几点原因。

……IQueryable 接口是.NET 提供的 Header Interface 中一个优秀的接口示例。不过,我们几乎没办法完整地实现这个接口。

言下之意就是说,你没法确保方法会返回 IQueryable 接口的一个完整实现。

虽然该接口非常灵活、表达力很强,但是有个例外,那就是我们总能够写出一个查询让给定的 provider(供应程序)没法转化。

IQueryable 唯一的完整实现是内存实现

Mark 说,这种方式会导致抽象泄露(leaky abstraction),因为大部分情况下 IQueryable 都会由代码中的 Store provider 实现。

虽然这种说法很有道理,但是反过来想想,抽象泄露又有多大问题呢?使用它至少能够在我们可接受的范围内让写代码变得简单些也说不定呢?

比方说,如果 ASP.NET Web API 的返回类型为 IQueryable,那么它可以通过请求参数让同样用于过滤数据的webapi 变得更加简单。类似地,WCF RIA Service 中的DomainContext 方法返回的也是IQueryable,客户端可以借助它可在XAML 中使用过滤描述符(filter descriptor)或从 JQuery 客户端中取回所需的数据。

亲爱的读者,你是怎么考虑的呢?灵活性带来的好处是否能盖过抽象泄露呢?

查看英文原文: Is IQueryable A Bad Choice For APIs?

2012-04-11 19:191846
用户头像

发布了 125 篇内容, 共 39.4 次阅读, 收获喜欢 5 次。

关注

评论

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

浅谈TypeScript对业务可维护性的影响

前夕

typescript 前端

顶级Layer-3 通证正在飙升,布局龙头Degen Chain(含bitget教程)

股市老人

Apache Doris 2.1.1 版本正式发布!

SelectDB

数据库 大数据 开源 数据分析 大数据 开源

从基础到高级,带你深入了解和使用curl命令(一)

霍格沃兹测试开发学社

链表反转

Echo!!!

typescript Reverse linkedlist

开发者怎么拥抱智能化浪潮?昇腾AI给出了“通关指南”

Alter

Drama queen

Echo!!!

English

智能座机方案建设与实践

之家技术

人工智能 企业号 4 月 PK 榜

反套路打工:王子公主职场图鉴

白洞计划

云计算

C++ While 和 For 循环:流程控制全解析

小万哥

程序人生 编程语言 软件工程 C/C++ 后端开发

《计算机程序设计艺术(第2卷)》PDF

程序员李木子

AI程序员上岗1年!四分之一代码都靠TA,还能检测修复安全漏洞!

百度安全

AIGC在广告创意上的实践

之家技术

大模型 AIGC 企业号 4 月 PK 榜

汽车之家人的“灵创”AI应用平台及编程助手AutoCode

之家技术

大模型 AIGC 企业号 4 月 PK 榜

AI广告创意生产实践

之家技术

大模型 AIGC 企业号 4 月 PK 榜

Databend 集成 PRQL:现代数据处理的一小步

Databend

全网唯一能够秒回粉丝的博主, 是如何做到的?

前夕

前端 Electron React 自媒体

从基础到高级,带你深入了解和使用curl命令(二)

霍格沃兹测试开发学社

苹果开发新款 AI 能「看懂」屏幕上内容;阿里未来 20% 代码将由 AI 编写丨 RTE 开发者日报 Vol.177

声网

pageSpy - 远程调试利器

前夕

前端 pagespy

汽车智能化多模态交互

之家技术

大模型 AIGC 企业号 4 月 PK 榜

IQueryable对于API是个错误的选择吗?_.NET_Roopesh Shenoy_InfoQ精选文章