导出 (0) 打印
全部展开
此文章由机器翻译。 将光标移到文章的句子上,以查看原文。 更多信息。
译文
原文

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

返回序列中的唯一元素;如果该序列为空,则返回默认值;如果该序列包含多个元素,此方法将引发异常。

命名空间:  System.Linq
程序集:  System.Core(在 System.Core.dll 中)

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

类型参数

TSource

source 中的元素的类型。

参数

source
类型:System.Collections.Generic.IEnumerable<TSource>
一个 IEnumerable<T>,用于返回单个元素。

返回值

类型:TSource
返回输入序列的单个元素;如果序列不包含任何元素,则返回 default(TSource)。

使用说明

在 Visual Basic 和 C# 中,可以在 IEnumerable<TSource> 类型的任何对象上将此方法作为实例方法来调用。当使用实例方法语法调用此方法时,请省略第一个参数。有关详细信息,请参阅扩展方法 (Visual Basic)扩展方法(C# 编程指南)

异常条件
ArgumentNullException

sourcenull

InvalidOperationException

输入序列包含多个元素。

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

SingleOrDefault 方法不提供任何方式来指定默认值。 如果您希望指定一个 default(TSource) 之外的默认值,请使用"示例"部分中介绍的 DefaultIfEmpty<TSource>(IEnumerable<TSource>, TSource) 方法。

下面的代码示例演示如何使用 SingleOrDefault<TSource>(IEnumerable<TSource>) 选择数组的唯一元素。


            string[] fruits1 = { "orange" };

            string fruit1 = fruits1.SingleOrDefault();

            Console.WriteLine(fruit1);

            /*
             This code produces the following output:

             orange
            */



下面的代码示例演示当序列不是恰好包含一个元素时 SingleOrDefault<TSource>(IEnumerable<TSource>) 将返回默认值。


            string[] fruits2 = { };

            string fruit2 = fruits2.SingleOrDefault();

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

            /*
             This code produces the following output:

             No such string!
            */



如果集合不包含任何元素,则有时 default(TSource) 的值不是您希望使用的默认值。 如果集合为空,则与其检查结果是否包含不需要的默认值,然后根据需要更改它,不如使用 DefaultIfEmpty<TSource>(IEnumerable<TSource>, TSource) 方法来指定您希望使用的默认值。 然后调用 Single<TSource>(IEnumerable<TSource>) 来获取元素。 下面的代码示例使用这两种方式,在页码的集合为空时获取默认值 1。 由于整数的默认值为 0,通常不是一个有效的页码,因此必须指定默认值为 1。 在查询执行完成之后,检查第一个结果变量是否为不需要的默认值。 通过使用 DefaultIfEmpty<TSource>(IEnumerable<TSource>, TSource) 将默认值指定为 1 来获取第二个结果变量。


            int[] pageNumbers = { };

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

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

            /*
             This code produces the following output:

             The value of the pageNumber1 variable is 1
             The value of the pageNumber2 variable is 1
            */



.NET Framework

受以下版本支持:4.5.2、4.5.1、4.5、4、3.5

.NET Framework Client Profile

受以下版本支持:4、3.5 SP1

可移植类库

受以下版本支持:可移植类库

适用于 Windows 应用商店应用的 .NET

受以下版本支持:Windows 8

适用于 Windows Phone 应用的 .NET

受以下版本支持:Windows Phone 8、Silverlight 8.1

Windows Phone 8.1, Windows Phone 8, Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008(不支持服务器核心角色), Windows Server 2008 R2(支持带 SP1 或更高版本的服务器核心角色;不支持 Itanium)

.NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参阅.NET Framework 系统要求

社区附加资源

添加
显示:
© 2015 Microsoft