C#3.0新增功能09 LINQ 标准查询运算符 03 按执行方式的分类

标准查询运算符方法的 LINQ to Objects 实现主要通过两种方法之一执行:立即执行和延迟执行。使用延迟执行的查询运算符可以进一步分为两种类别:流式处理和非流式处理。 如果你了解不同查询运算符的执行方式,则有助于理解从给定查询中获得的结果。 如果数据源是不断变化的,或者如果你要在另一个查询的基础上构建查询,这种帮助尤其明显。 本篇根据标准查询运算符的执行方式对其进行分类。

执行方式

即时

立即执行指的是在代码中声明查询的位置读取数据源并执行运算。 返回单个不可枚举的结果的所有标准查询运算符都立即执行。

推迟

延迟执行指的是不在代码中声明查询的位置执行运算。 仅当对查询变量进行枚举时才执行运算,例如通过使用 foreach 语句执行。 这意味着,查询的执行结果取决于执行查询而非定义查询时的数据源内容。 如果多次枚举查询变量,则每次结果可能都不同。 几乎所有返回类型为 IEnumerable<T>IOrderedEnumerable<TElement> 的标准查询运算符皆以延迟方式执行。

使用延迟执行的查询运算符可以另外分类为流式处理和非流式处理。

流式处理

流式处理运算符不需要在生成元素前读取所有源数据。 在执行时,流式处理运算符一边读取每个源元素,一边对该源元素执行运算,并在可行时生成元素。 流式处理运算符将持续读取源元素直到可以生成结果元素。 这意味着可能要读取多个源元素才能生成一个结果元素。

非流式处理

非流式处理运算符必须先读取所有源数据,然后才能生成结果元素。 排序或分组等运算均属于此类别。 在执行时,非流式处理查询运算符将读取所有源数据,将其放入数据结构,执行运算,然后生成结果元素。

分类表

下表按照执行方法对每个标准查询运算符方法进行了分类。

如果某个运算符被标入两个列中,则表示在运算中涉及两个输入序列,每个序列的计算方式不同。 在此类情况下,参数列表中的第一个序列始终以延迟流式处理方式来执行计算。

标准查询运算符

返回类型

立即执行

延迟的流式处理执行

延迟非流式处理执行

Aggregate

TSource

X

All

Boolean

X

Any

Boolean

X

AsEnumerable

IEnumerable<T>

X

Average

单个数值

X

Cast

IEnumerable<T>

X

Concat

IEnumerable<T>

X

Contains

Boolean

X

Count

Int32

X

DefaultIfEmpty

IEnumerable<T>

X

Distinct

IEnumerable<T>

X

ElementAt

TSource

X

ElementAtOrDefault

TSource

X

Empty

IEnumerable<T>

X

Except

IEnumerable<T>

X

X

First

TSource

X

FirstOrDefault

TSource

X

GroupBy

IEnumerable<T>

X

GroupJoin

IEnumerable<T>

X

X

Intersect

IEnumerable<T>

X

X

Join

IEnumerable<T>

X

X

Last

TSource

X

LastOrDefault

TSource

X

LongCount

Int64

X

Max

单个数值、TSource 或 TResult

X

Min

单个数值、TSource 或 TResult

X

OfType

IEnumerable<T>

X

OrderBy

IOrderedEnumerable<TElement>

X

OrderByDescending

IOrderedEnumerable<TElement>

X

Range

IEnumerable<T>

X

Repeat

IEnumerable<T>

X

Reverse

IEnumerable<T>

X

Select

IEnumerable<T>

X

SelectMany

IEnumerable<T>

X

SequenceEqual

Boolean

X

Single

TSource

X

SingleOrDefault

TSource

X

Skip

IEnumerable<T>

X

SkipWhile

IEnumerable<T>

X

Sum

单个数值

X

Take

IEnumerable<T>

X

TakeWhile

IEnumerable<T>

X

ThenBy

IOrderedEnumerable<TElement>

X

ThenByDescending

IOrderedEnumerable<TElement>

X

ToArray

TSource 数组

X

ToDictionary

Dictionary<TKey,TValue>

X

ToList

IList<T>

X

ToLookup

ILookup<TKey,TElement>

X

Union

IEnumerable<T>

X

Where

IEnumerable<T>

X

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java技术栈

Redis基础都不会,好意思出去面试?

Redis支持多种不同的数据结构,包括5种基础数据结构和几种比较复杂的数据,这些数据结构可以满足不同的应用场景。

11220
来自专栏java技术大本营

JVM|01基础指令

在本地开发环境中我们很少会遇到需要对jvm进行优化的需求,但是到了生产环境,我们 可能将有下面的需求: 运行的应用“卡住了”,日志不输出,程序没有反应 服务器的...

10620
来自专栏GitHubDaily

GitHub 标星 1.6 万!最全中文 LeetCode 题解项目助你学好算法!

当代程序员的困惑可能大致分为两类:一是 "35 岁之后我该去往何处",二是 "如何才能进入互联网大厂工作"。

12110
来自专栏FreeBuf

实战某游戏厂商FPS游戏CRC检测的对抗与防护

不得不说,随着时代的发展,游戏产业在近几年的互联网潮流中越来越扮演者重要的地位,与之而来的不仅有网络游戏公司的春天,还有游戏灰色产业的暗流涌动。在游戏产业的发展...

22210
来自专栏五分钟学算法

准备下次编程面试前你应该知道的数据结构

国外 IT 教育学院 Educative.io 创始人 Fahim ul Haq 写过一篇过万赞的文章《The top data structures you ...

13610
来自专栏python学习教程

Python往这个方向走,绝对没有错

近几年Python的受欢迎程度可谓是扶摇直上,当然了学习的人也是愈来愈多。一些学习Python的小白在学习初期,总希望能够得到一份Python学习路线图,小编经...

11810
来自专栏五分钟学算法

图解「剑指Offer」之使用栈实现队列

这是一道很典型的为初级算法爱好者准备的算法题,首先简单介绍一下 队列 和 栈 这两种数据结构。

8620
来自专栏程序猿杂货铺

程序命名的一些提示

选择一个正确的名字是编程中最重要的事。一个正确的命名可以让你更容易地理解代码的程序,好的命名可以消除二义性,消除误解,并且说明真实的意图,甚至可以让你有清新的气...

9030
来自专栏小强的进阶之路

工作中遇到的99%SQL优化,这里都能给你解决方案

前几篇文章介绍了mysql的底层数据结构和mysql优化的神器explain。 BAT大厂都会问的MySQL底层数据结构 一线互联网公司必问的MySql优化...

8320
来自专栏Spark学习技巧

数据库索引原理及优化

本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题。特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MyS...

17330

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励