写点什么

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

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

关注

评论

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

使用Redisson优雅关闭订单

码农参上

redission 8月日更

JAVA 规范

gin

类加载机制

wzh

Java 面试 JVM 类加载器 JVM类加载

Java技术开发专题系列之【Guava Collections】实战使用相关Guava不一般的集合框架

码界西柚

Java Guava 8月日更 Guava Collections

@ConditionOnClass的使用

Rubble

8月日更

【布道API】权限错误码选择:401、403 或 404

devpoint

HTTP Authorization REST API 8月日更

策略模式

wzh

面试 设计模式 策略模式

Vue进阶(五十四):vue-cli 脚手架 dev-server.js 配置文件详解

No Silver Bullet

Vue 8月日更

Java web程序的运行时环境

wzh

Java tomcat 面试 Web JVM

Android.mk

Changing Lin

8月日更

为了完成小姐姐安排的打分系统,又熬了一个小时的夜补充视图与模板

梦想橡皮擦

8月日更

装饰器模式

wzh

面试 设计模式 装饰器

JVM内存划分

wzh

面试 JVM 方法区

模块五作业

seawolflin

架构训练营

Android开发:新建后缀为txt的文件并且使用的步骤

三掌柜

8月日更 8月

手撸二叉树之合并二叉树

HelloWorld杰少

8月日更 数据结构算法

vue入门:vuex概括与使用

小鲍侃java

8月日更

Go- 字符串

HelloBug

索引 字符串 Go 语言 拼接 长度

java操作sql server数据库

Python研究者

8月日更

如此爱国,必然自毁长城

箭上有毒

8月日更

几种常用设计模式的简单示例

编程三昧

JavaScript 大前端 设计模式 8月日更

四种常见的 POST 提交数据方式

一个大红包

8月日更

Nginx-基本概念和使用

Rubble

8月日更

ShardingSphere源码解析 初步准备

Java 源码 ShardingSphere

IDEA2020.1构建Spring5.2.x源码

4ye

Java spring 源码 后端 8月日更

JVM GC机制

wzh

面试 JVM 垃圾回收 GC GC Root

Golang协程之了解管道的缓存能力

Regan Yue

协程 Go 语言 8月日更

Android EditText输入框实现下拉且保存最近5个历史记录

Andy阿辉

android Android 小菜鸟 编程思想 8月日更

kubernetes/k8s CNI 分析 - 容器网络接口分析

良凯尔

Kubernetes 源码分析 Kubernetes Plugin #Kubernetes# cni

观察者模式

wzh

面试 设计模式 观察者模式

回调模式

wzh

面试 设计模式 回调函数

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