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

Enumerable.FirstOrDefault<TSource> 方法 (IEnumerable<TSource>)

 

返回序列中的第一个元素;如果序列中不包含任何元素,则返回默认值。

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

public static TSource FirstOrDefault<TSource>(
	this IEnumerable<TSource> source
)

参数

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

IEnumerable<T> 要返回的第一个元素。

返回值

Type: TSource

default(TSource) 如果 source 空; 否则为中的第一个元素 source

类型参数

TSource

中的元素的类型 source

Exception Condition
ArgumentNullException

sourcenull

默认值为引用类型和可以为 null 的类型 null

FirstOrDefault 方法不提供任何方式来指定默认值。 如果你想要指定默认值以外 default(TSource),使用 DefaultIfEmpty<TSource>(IEnumerable<TSource>, TSource) 示例部分中所述的方法。

下面的代码示例演示如何使用 FirstOrDefault<TSource>(IEnumerable<TSource>) 对空数组。

int[] numbers = { };
int first = numbers.FirstOrDefault();
Console.WriteLine(first);

/*
 This code produces the following output:

 0
*/

值有时 default(TSource) 不是您如果想要使用该集合不包含任何元素的默认值。 而不是检查结果是否不需要的默认值,然后更改有必要,您可以使用 DefaultIfEmpty<TSource>(IEnumerable<TSource>, TSource) 方法,以指定你想要集合为空时使用的默认值。 然后,调用 First<TSource>(IEnumerable<TSource>) 若要获取的第一个元素。 下面的代码示例使用这两种方法来获取默认值为 1,数字月份的集合是否为空。 由于一个整数,默认值 0,并不对应的任何月份,因此必须指定默认值为 1。 查询执行完毕后,检查第一个结果变量为不需要的默认值。 第二个结果变量通过使用获取 DefaultIfEmpty<TSource>(IEnumerable<TSource>, TSource) 若要指定默认值为 1。

List<int> months = new List<int> { };

// Setting the default value to 1 after the query.
int firstMonth1 = months.FirstOrDefault();
if (firstMonth1 == 0)
{
    firstMonth1 = 1;
}
Console.WriteLine("The value of the firstMonth1 variable is {0}", firstMonth1);

// Setting the default value to 1 by using DefaultIfEmpty() in the query.
int firstMonth2 = months.DefaultIfEmpty(1).First();
Console.WriteLine("The value of the firstMonth2 variable is {0}", firstMonth2);

/*
 This code produces the following output:

 The value of the firstMonth1 variable is 1
 The value of the firstMonth2 variable is 1
*/

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