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

Enumerable.OrderBy<TSource, TKey> 方法 (IEnumerable<TSource>, Func<TSource, TKey>)

根据键按升序对序列的元素排序。

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

public static IOrderedEnumerable<TSource> OrderBy<TSource, TKey>(
	this IEnumerable<TSource> source,
	Func<TSource, TKey> keySelector
)

类型参数

TSource

source 中的元素的类型。

TKey

keySelector 返回的键的类型。

参数

source
类型:System.Collections.Generic.IEnumerable<TSource>
一个要排序的值序列。
keySelector
类型:System.Func<TSource, TKey>
用于从元素中提取键的函数。

返回值

类型:System.Linq.IOrderedEnumerable<TSource>
一个 IOrderedEnumerable<TElement>,其元素按键排序。

使用说明

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

异常条件
ArgumentNullException

sourcekeySelectornull

此方法通过使用延迟执行实现。 即时返回值为一个对象,该对象存储执行操作所需的所有信息。 只有通过直接调用对象的 GetEnumerator 方法或使用 Visual C# 中的 foreach(或 Visual Basic 中的 For Each)来枚举该对象时,才执行此方法表示的查询。

若要按元素自身的值对序列进行排序,请为 keySelector 指定标识函数(在 Visual C# 中为 x => x;在 Visual Basic 中为 Function(x) x)。

定义了两种方法来扩展 IOrderedEnumerable<TElement> 类型,该类型为此方法的返回类型。 这两种方法(即 ThenByThenByDescending)使您能够指定附加排序条件,以便对序列进行排序。 ThenByThenByDescending 还返回一个 IOrderedEnumerable<TElement>,这意味着可对 ThenByThenByDescending 执行任意数量的连续调用。

说明说明

由于 IOrderedEnumerable<TElement> 继承自 IEnumerable<T>,因此您可以根据对 OrderByOrderByDescendingThenByThenByDescending 的调用结果来调用 OrderByOrderByDescending 执行此操作会产生一个新的主排序,它忽略以前建立的排序。

此方法使用默认的比较器 Default 对键进行比较。

此方法执行稳定排序,也就是说,如果两个元素的键相同,则保留这两个元素的顺序。 相反,不稳定排序不保留具有相同键的元素的顺序。

在查询表达式语法中,orderby (Visual C#) 或 Order By (Visual Basic) 子句转换为 OrderBy 的一个调用。

下面的代码示例演示如何使用 OrderBy<TSource, TKey>(IEnumerable<TSource>, Func<TSource, TKey>) 对序列的元素进行排序。


            class Pet
            {
                public string Name { get; set; }
                public int Age { get; set; }
            }

            public static void OrderByEx1()
            {
                Pet[] pets = { new Pet { Name="Barley", Age=8 },
                               new Pet { Name="Boots", Age=4 },
                               new Pet { Name="Whiskers", Age=1 } };

                IEnumerable<Pet> query = pets.OrderBy(pet => pet.Age);

                foreach (Pet pet in query)
                {
                    Console.WriteLine("{0} - {1}", pet.Name, pet.Age);
                }
            }

            /*
             This code produces the following output:

             Whiskers - 1
             Boots - 4
             Barley - 8
            */



.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 系统要求

社区附加资源

添加
显示:
© 2014 Microsoft