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

Enumerable.Select<TSource, TResult> 方法 (IEnumerable<TSource>, Func<TSource, TResult>)

 

将序列中的每个元素投影到新表单。

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

public static IEnumerable<TResult> Select<TSource, TResult>(
	this IEnumerable<TSource> source,
	Func<TSource, TResult> selector
)

参数

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

一个值序列,要对该序列调用转换函数。

selector
Type: System.Func<TSource, TResult>

应用于每个元素的转换函数。

返回值

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

IEnumerable<T> 其元素是调用转换函数的每个元素的结果 source

类型参数

TSource

中的元素的类型 source

TResult

返回的值的类型 selector

Exception Condition
ArgumentNullException

sourceselectornull

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

此投影方法需要转换函数, selector, ,以生成一个值,为源序列中每个值 source 如果 selector 返回一个值,本身为一个集合,它负责的使用者手动遍历子序列。 在这种情况下,可能是你的查询以返回单个值的合并的序列中的显示效果会更好。 若要实现此目的,请使用 SelectMany<TSource, TResult> 方法而不是 Select<TSource, TResult> 尽管 SelectMany 工作原理类似于 Select, ,它不同之处在于转换函数返回一个集合,然后通过扩展 SelectMany 它返回的状态之前。

在查询表达式语法 select (Visual C#) 或 Select (Visual Basic) 子句转换为的一个调用 Select

下面的代码示例演示如何使用 Select<TSource, TResult>(IEnumerable<TSource>, Func<TSource, TResult>) 到对一个序列值的项目。

IEnumerable<int> squares =
    Enumerable.Range(1, 10).Select(x => x * x);

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

 1
 4
 9
 16
 25
 36
 49
 64
 81
 100
*/

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