本文由机器翻译。若要查看英语原文,请勾选“英语”复选框。 也可将鼠标指针移到文本上,在弹出窗口中显示英语原文。
翻译
英语

Enumerable.Where<TSource> 方法 (IEnumerable<TSource>, Func<TSource, Int32, Boolean>)

 

基于谓词筛选值序列。 将在谓词函数的逻辑中使用每个元素的索引。

命名空间:   System.Linq
程序集:  System.Core(位于 System.Core.dll)

public static IEnumerable<TSource> Where<TSource>(
	this IEnumerable<TSource> source,
	Func<TSource, int, bool> predicate
)

参数

source
Type: System.Collections.Generic.IEnumerable<TSource>

IEnumerable<T> 进行筛选。

predicate
Type: System.Func<TSource, Int32, Boolean>

用于测试每个源元素是否满足条件的函数;该函数的第二个参数表示源元素的索引。

返回值

Type: System.Collections.Generic.IEnumerable<TSource>

IEnumerable<T> ,其中包含输入序列中满足条件的元素。

类型参数

TSource

中的元素的类型 source

Exception Condition
ArgumentNullException

sourcepredicatenull

此方法实现通过使用延迟的执行。 最接近的返回值是指存储执行的操作所需的所有信息的对象。 此方法所表示的查询不执行之前调用枚举的对象及其 GetEnumerator 方法直接或通过使用 foreach 中 Visual C# 或 For Each 中 Visual Basic。

第一个参数的 predicate 表示要测试的元素。 第二个参数表示中的元素的从零开始索引 source

下面的代码示例演示如何使用 Where<TSource>(IEnumerable<TSource>, Func<TSource, Int32, Boolean>) 来筛选序列基于谓词,其中涉及到的每个元素的索引。

int[] numbers = { 0, 30, 20, 15, 90, 85, 40, 75 };

IEnumerable<int> query =
    numbers.Where((number, index) => number <= index * 10);

foreach (int number in query)
{
    Console.WriteLine(number);
}
/*
 This code produces the following output:

 0
 20
 15
 40
*/

通用 Windows 平台
自 8 起可用
.NET Framework
自 3.5 起可用
可移植类库
可移植 .NET 平台 中受支持
Silverlight
自 2.0 起可用
Windows Phone Silverlight
自 7.0 起可用
Windows Phone
自 8.1 起可用
返回页首
显示: