写点什么

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

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

关注

评论

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

Mac系统设置维护工具TinkerTool System for Mac

兮兮立立

安全加密的即时通讯软件,统一门户高效互联

BeeWorks

即时通讯 IM 私有化部署

揭秘 JVM 停顿的背后:深入理解 Safepoint

mazhen

Java Linux JVM GC Performance

音频元数据编辑器Tagr for Mac v5.8.1

兮兮立立

Tagr下载 Tagr mac Tagr破解版

EdgeView for Mac 图片浏览查看编辑软件

兮兮立立

为什么说普通人想要从新一轮 Web3 市场红利受益,就一定要PSP?

股市老人

WiFi无线网络管理工具 WiFi Explorer Pro for Mac

兮兮立立

专业远程桌面连接工具Microsoft Remote Desktop

Geek贝

回归开源,两位 Java 和 Go 程序员分享的开源贡献指引

阿里巴巴云原生

阿里云 云原生 Higress

文件快捷拖放管理工具Dropzone 4 for Mac

兮兮立立

BetterTouchTool for Mac(触控板增强神器)

Geek贝

低代码:深度切入制造业软件系统需求的实践路径

秃头小帅oi

妙笔写作软件WonderPen for Mac v2.6.9

兮兮立立

WonderPen妙笔 WonderPen下载 WonderPen中文版 WonderPen激活版

Dynamic Wallpaper for Mac 精美动态壁纸下载器

兮兮立立

MacCleanse for Mac 系统垃圾清理软件

兮兮立立

北京市科委发布《北京市加快人工智能赋能科学研究高质量发展行动计划》

ModelWhale

政策 科学智能 北京市科委

正规合肥等保测评机构名单汇总2025

行云管家

网络安全 等保 等保测评

Open WebUI 和 Dify 在构建企业AI应用时的主要区别

测试人

从接入到销毁:可信数据空间如何为医疗数据合规护航?

郑州埃文科技

数据要素 可信数据

【华为云MySQL技术专栏】TaurusDB增备功能介绍

华为云开发者联盟

表单文本框里写太多字就出 404 了?原因和解决办法都在这儿!

不在线第一只蜗牛

表单

MySQL 逻辑架构说明

量贩潮汐·WholesaleTide

MySQL

内网即时通讯软件BeeWorks,支持私有化局域网使用

BeeWorks

即时通讯 IM 私有化部署

SMART Utility for mac (磁盘诊断工具)

Geek贝

DS豆包通义BTY王炸组合,我做了个元宵AI视频小程序

BetterYeah AI

如何用DeepSeek让你的营销、开发、客服Agent更强大?

BetterYeah AI

和鲸助力!华中附属同济医院DataLab数据服务一体化平台荣获第7届医学创新大会数智化医学创新典型案例

ModelWhale

同济医院 和鲸 CMIA

Kimi K2开源炸场,1万亿参数碾压GPT-4.1,成本仅Claude 4的1/5!

测试人

视频画质无损修复软件Aiarty Video Enhancer for Mac

兮兮立立

全能电子书阅读管理工具 OmniReader Pro for Mac

兮兮立立

Docker容器访问挂载文件权限问题

电子尖叫食人鱼

Docker 容器 运维

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