写点什么

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

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

关注

评论

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

TASKCTL 作业流程无触发设计

敏捷调度TASKCTL

大数据 DevOps 分布式 自动化部署 ETL任务

如何添加字体?

InfoQ IT百科

Carina 本地存储入选 CNCF 云原生全景图

BoCloud博云

开源 cncf 本地存储

TASKCTL 容器签出失败解决方法

敏捷调度TASKCTL

大数据 DevOps 分布式 ETL 自动化运维

App分发是什么意思?

InfoQ IT百科

怎么做App分发?

InfoQ IT百科

移动App的设计流程是怎样的?

InfoQ IT百科

从杀慢查询入手来预防 MySQL 雪崩的办法

Qunar技术沙龙

dba

如何部署自己的网站?

InfoQ IT百科

主流的网站服务器架构有哪些?

InfoQ IT百科

现在常用的在线协作文档软件有哪些?

InfoQ IT百科

目前WPS支持在哪些设备上使用?

InfoQ IT百科

Docker 实战教程之从入门到提高 (八)

汪子熙

Docker 容器 docker image 容器镜像 4月月更

App怎么做灰度发布?

InfoQ IT百科

有哪些适合程序员用的笔记应用?

InfoQ IT百科

有哪些好用的代码编辑器?

InfoQ IT百科

注册域名后,怎么创建个人网站?

InfoQ IT百科

App能收集哪些个人信息?

InfoQ IT百科

怎么做SEO网站优化?

InfoQ IT百科

怎么让网站在搜索结果中排更前?

InfoQ IT百科

一个WPS账号可以在多个设备同时登陆吗?

InfoQ IT百科

毕设:设计电商秒杀系统

王大胖

如何修改电脑文件格式?

InfoQ IT百科

WPS是什么软件?

InfoQ IT百科

Java篇-序列化与反序列化

是老郭啊

Java 对象 序列化 反序列化

如何优雅高效地管理公司文档?

小炮

文档 文档管理

阿里云 云效一站式研发平台

阿里云云效

阿里云 DevOps 云原生 研发 一站式研发平台

WPS有哪些隐藏的使用小技巧?

InfoQ IT百科

数据连接一切,开启融合数据云新时代——星环科技春季新品发布周盛大开启

星环科技

现在常用的视频会议软件有哪些?

InfoQ IT百科

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