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

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

 

返回序列中满足指定条件的唯一元素;如果有多个这样的元素存在,则会引发异常。

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

public static TSource Single<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

输入序列中满足条件的单个元素。

类型参数

TSource

中的元素的类型 source

Exception Condition
ArgumentNullException

sourcepredicatenull

InvalidOperationException

没有元素满足该条件在 predicate

- 或 -

多个元素满足该条件在 predicate

- 或 -

源序列为空。

Single<TSource>(IEnumerable<TSource>, Func<TSource, Boolean>) 方法将引发异常,如果输入的序列中不包含任何匹配元素。 若要返回 null 找到任何匹配元素时,使用 SingleOrDefault<TSource>

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

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

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

Console.WriteLine(fruit1);

/*
 This code produces the following output:

 passionfruit
*/

下面的代码示例演示 Single<TSource>(IEnumerable<TSource>, Func<TSource, Boolean>) 序列不包含恰好一个元素满足条件时引发异常。

string fruit2 = null;

try
{
    fruit2 = fruits.Single(fruit => fruit.Length > 15);
}
catch (System.InvalidOperationException)
{
    Console.WriteLine(@"The collection does not contain exactly 
                    one element whose length is greater than 15.");
}

Console.WriteLine(fruit2);

// This code produces the following output:
//
// The collection does not contain exactly  
// one element whose length is greater than 15.

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