标准查询运算符按执行方式的分类
更新:2007 年 11 月
标准查询运算符方法的 LINQ to Objects 实现采用两种主要方式之一来执行:立即执行和延迟执行。采用延迟执行的查询运算符可以进一步分为两类:流式和非流式。如果您了解不同的查询运算符如何执行,则有助于理解从给定的查询获得的结果。如果数据源是不断变化的,或者如果您要在另一个查询的基础上构建查询,则获得的帮助尤其明显。本主题按照标准查询运算符的执行方式对其进行分类。
执行方式
立即
立即执行意味着在代码中声明查询的位置读取数据源并执行运算。返回单个不可枚举的结果的所有标准查询运算符都立即执行。
延迟
延迟执行意味着不在代码中声明查询的位置执行运算。仅当对查询变量进行枚举操作时才执行运算,例如通过使用 foreach(在 Visual Basic 中为 For Each)语句。这意味着查询的执行结果取决于执行查询而非定义查询时的数据源内容。如果多次枚举查询变量,则每次结果可能都不同。几乎所有返回类型为 IEnumerable<T> 或 IOrderedEnumerable<TElement> 的标准查询运算符都以延迟方式执行。
采用延迟执行方式的查询运算符可以另外分类为流式和非流式。
流式
流式运算符不需要在生成元素前读取所有源数据。在执行时,流式运算符一边读取每个源元素,一边对该源元素执行运算,并在可行时生成元素。流式运算符将持续读取源元素直到可以生成结果元素。这意味着可能要读取多个源元素才能生成一个结果元素。
非流式
非流式运算符必须读取所有源数据才能生成结果元素。诸如排序和分组等运算属于此类别。在执行时,非流式查询运算符读取所有源数据,将其放入数据结构中,执行运算,然后生成结果元素。
分类表
下表按照执行方法对每个标准查询运算符方法进行了分类。
说明: |
---|
如果某个运算符被标入两个列中,则表示在运算中涉及两个输入序列,每个序列的计算方式不同。在此类情况下,参数列表中的第一个序列始终以延迟流式方式来执行计算。 |
标准查询运算符 |
返回类型 |
立即执行 |
延迟流式执行 |
延迟非流式执行 |
---|---|---|---|---|
TSource |
X |
|
|
|
X |
|
|
||
X |
|
|
||
X |
|
|||
单个数值 |
X |
|
|
|
|
X |
|
||
|
X |
|
||
X |
|
|
||
X |
|
|
||
|
X |
|
||
|
X |
|
||
TSource |
X |
|
|
|
TSource |
X |
|
|
|
X |
|
|
||
X |
X |
|||
TSource |
X |
|
|
|
TSource |
X |
|
|
|
|
|
X |
||
X |
X |
|||
X |
X |
|||
X |
X |
|||
TSource |
X |
|
|
|
TSource |
X |
|
|
|
X |
|
|
||
单个数值、TSource 或 TResult |
X |
|
|
|
单个数值、TSource 或 TResult |
X |
|
|
|
|
X |
|
||
|
|
X |
||
|
|
X |
||
|
X |
|
||
|
X |
|
||
|
|
X |
||
|
X |
|
||
|
X |
|
||
X |
|
|
||
TSource |
X |
|
|
|
TSource |
X |
|
|
|
|
X |
|
||
|
X |
|
||
单个数值 |
X |
|
|
|
|
X |
|
||
|
X |
|
||
|
|
X |
||
|
|
X |
||
TSource 数组 |
X |
|
|
|
X |
|
|
||
X |
|
|
||
X |
|
|
||
|
X |
|
||
|
X |
|