NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

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

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

关注

评论

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

架构训练营模块四作业

Neil43

架构训练营

思考题太难了

Nydia

架构实战营模块 4 作业

梦寻解语花

架构实战营

会说话的ABAP report

Jerry Wang

SAP abap SAPGUI

人生算法:做事要闭环

石云升

读书笔记 职场经验 5月日更 人生算法

SAP UI5和CRM WebUI的View和Controller是如何绑定的

Jerry Wang

CRM SAP abap WebClient UI SAP UI5

sap.ui.require in SAP UI5 and require in nodejs

Jerry Wang

nodejs SAP SAP UI5

过拟合 - DAY13

Qien Z.

5月日更 过拟合

华仔架构训练营作业(模块四)

不听不听王八念晶

千万级学生管理系统的考试试卷存储方案

Lane

如何查看某个用户指定时间段的ABAP开发记录

Jerry Wang

SAP abap SAPGUI

第四课作业

杰语

你真的会用ABAP, Java和JavaScript里的constructor么?

Jerry Wang

JavaScript CRM SAP abap

ABAP的include关键字,Java的import, C的include和C4C ABSL 的import比较

Jerry Wang

JavaScript nodejs CRM SAP C4C

使用ABAP Push Channel(APC)开发的乒乓球游戏,可双打

Jerry Wang

SAP abap APC

架构实战营 模块四作业

夏日

架构实战营

优化docker镜像的几种方法

运维研习社

Docker 镜像 优化技巧 5月日更

S4HANA和CRM Fiori应用的搜索分页实现

Jerry Wang

CRM SAP Fiori SAP UI5 S/4HANA

SAP UI5, CRM, S/4HANA 和 C4C里的Association, Composition and Aggregation

Jerry Wang

JavaScript CRM SAP SAP UI5

今天社区团购了吗?

lenka

5月日更

作业 - 设计千万级学生管理系统的考试试卷存储方案

sN0wpeak

架构实战营

架构实战营 模块4 作业

CR

身份认证

escray

学习 极客时间 安全 5月日更 安全攻防技能30讲

Dubbo 令牌验证和优雅停机

青年IT男

dubbo

如何计算并测量ABAP及Java代码的环复杂度Cyclomatic complexity

Jerry Wang

Java SAP abap

那些年我用过的SAP IDE

Jerry Wang

ide SAP abap SAPGUI

S/4HANA for Customer Management里的搜索分页处理

Jerry Wang

CRM SAP abap S/4HANA

SAP Fiori里的List是如何做到懒加载Lazy load的

Jerry Wang

JavaScript SAP Fiori SAP UI5

S4CRM和C4C的技术比较

Jerry Wang

CRM SAP ERP abap Cloud for Customer

如何实现一个简易版的 Spring - 如何实现 AOP(上)

mghio

Java 技术 后端 基础知识 spring aop

千万级学生管理系统的考试试卷存储方案

王瑞强

架构实战营

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