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

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

 

返回序列中满足指定条件的唯一元素;如果这类元素不存在,则返回默认值;如果有多个元素满足该条件,此方法将引发异常。

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

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

参数

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

IEnumerable<T> 以返回从的单个元素。

predicate
Type: System.Func<TSource, Boolean>

用于测试元素是否满足条件的函数。

返回值

Type: TSource

输入序列中满足该条件的单个元素或 default(TSource) 如果找到这样的元素。

类型参数

TSource

中的元素的类型 source

Exception Condition
ArgumentNullException

sourcepredicatenull

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

下面的代码示例演示如何使用 SingleOrDefault<TSource>(IEnumerable<TSource>, Func<TSource, Boolean>) 来选择数组中满足条件的唯一元素。

string[] fruits = { "apple", "banana", "mango", 
                      "orange", "passionfruit", "grape" };

string fruit1 = fruits.SingleOrDefault(fruit => fruit.Length > 10);

Console.WriteLine(fruit1);

/*
 This code produces the following output:

 passionfruit
*/

下面的代码示例演示 SingleOrDefault<TSource>(IEnumerable<TSource>, Func<TSource, Boolean>) 序列不包含恰好一个元素满足条件时将返回默认值。

string fruit2 =
    fruits.SingleOrDefault(fruit => fruit.Length > 15);

Console.WriteLine(
    String.IsNullOrEmpty(fruit2) ? "No such string!" : fruit2);

/*
 This code produces the following output:

 No such string!
*/

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