Enumerable.OrderBy 메서드

정의

시퀀스의 요소를 오름차순으로 정렬합니다.

오버로드

OrderBy<TSource,TKey>(IEnumerable<TSource>, Func<TSource,TKey>)

시퀀스의 요소를 키에 따라 오름차순으로 정렬합니다.

OrderBy<TSource,TKey>(IEnumerable<TSource>, Func<TSource,TKey>, IComparer<TKey>)

지정된 비교자를 사용하여 시퀀스의 요소를 오름차순으로 정렬합니다.

OrderBy<TSource,TKey>(IEnumerable<TSource>, Func<TSource,TKey>)

시퀀스의 요소를 키에 따라 오름차순으로 정렬합니다.

public:
generic <typename TSource, typename TKey>
[System::Runtime::CompilerServices::Extension]
 static System::Linq::IOrderedEnumerable<TSource> ^ OrderBy(System::Collections::Generic::IEnumerable<TSource> ^ source, Func<TSource, TKey> ^ keySelector);
public static System.Linq.IOrderedEnumerable<TSource> OrderBy<TSource,TKey> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,TKey> keySelector);
static member OrderBy : seq<'Source> * Func<'Source, 'Key> -> System.Linq.IOrderedEnumerable<'Source>
<Extension()>
Public Function OrderBy(Of TSource, TKey) (source As IEnumerable(Of TSource), keySelector As Func(Of TSource, TKey)) As IOrderedEnumerable(Of TSource)

형식 매개 변수

TSource

source 요소의 형식입니다.

TKey

keySelector에서 반환하는 키의 형식입니다.

매개 변수

source
IEnumerable<TSource>

정렬할 값의 시퀀스입니다.

keySelector
Func<TSource,TKey>

요소에서 키를 추출하는 함수입니다.

반환

요소가 키에 따라 정렬된 IOrderedEnumerable<TElement>입니다.

예외

source 또는 keySelectornull인 경우

예제

다음 코드 예제에서는 를 사용하여 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
*/
Structure Pet
    Public Name As String
    Public Age As Integer
End Structure

Sub OrderByEx1()
    ' Create an array of Pet objects.
    Dim pets() As Pet = {New Pet With {.Name = "Barley", .Age = 8},
                     New Pet With {.Name = "Boots", .Age = 4},
                     New Pet With {.Name = "Whiskers", .Age = 1}}

    ' Order the Pet objects by their Age property.
    Dim query As IEnumerable(Of Pet) =
    pets.OrderBy(Function(pet) pet.Age)

    Dim output As New System.Text.StringBuilder
    For Each pt As Pet In query
        output.AppendLine(pt.Name & " - " & pt.Age)
    Next

    ' Display the output.
    Console.WriteLine(output.ToString())
End Sub

' This code produces the following output:
'
' Whiskers - 1
' Boots - 4
' Barley - 8

설명

이 메서드는 지연 된 실행을 사용 하 여 구현 됩니다. 즉시 반환 값은 작업을 수행 하는 데 필요한 모든 정보를 저장 하는 개체입니다. 이 메서드가 나타내는 쿼리는 개체를 직접 호출 GetEnumerator 하거나 C# 또는 For Each Visual Basic에서 를 사용하여 foreach 개체를 열거할 때까지 실행되지 않습니다.

요소 자체의 값으로 시퀀스를 정렬하려면 에 대한 ID 함수(x => x C# 또는 Function(x) x Visual Basic의 경우)를 keySelector지정합니다.

이 메서드의 반환 형식인 형식 IOrderedEnumerable<TElement>을 확장하기 위해 두 가지 메서드가 정의됩니다. 이러한 두 메서드, 즉 ThenByThenByDescending를 사용하면 시퀀스를 정렬하는 추가 정렬 조건을 지정할 수 있습니다. ThenByThenByDescendingIOrderedEnumerable<TElement>또는 ThenByDescending 에 대한 연속 호출 ThenBy 수를 의미하며 를 반환합니다.

참고

는 에서 IEnumerable<T>상속되므로 IOrderedEnumerable<TElement> , ThenByOrderByDescending또는 에 대한 호출 결과에서 또는 ThenByDescendingOrderByDescending 를 호출 OrderByOrderBy수 있습니다. 이렇게 하면 이전에 설정된 순서를 무시하는 새 기본 순서가 도입됩니다.

이 메서드는 기본 비교자 를 사용하여 키를 비교합니다 Default.

이 메서드는 안정적인 정렬을 수행합니다. 즉, 두 요소의 키가 같으면 요소의 순서가 유지됩니다. 반면 불안정한 정렬은 키가 같은 요소의 순서를 유지하지 않습니다.

쿼리 식 구문 orderby 에서 (C#) 또는 Order By (Visual Basic) 절은 의 OrderBy호출로 변환됩니다.

추가 정보

적용 대상

OrderBy<TSource,TKey>(IEnumerable<TSource>, Func<TSource,TKey>, IComparer<TKey>)

지정된 비교자를 사용하여 시퀀스의 요소를 오름차순으로 정렬합니다.

public:
generic <typename TSource, typename TKey>
[System::Runtime::CompilerServices::Extension]
 static System::Linq::IOrderedEnumerable<TSource> ^ OrderBy(System::Collections::Generic::IEnumerable<TSource> ^ source, Func<TSource, TKey> ^ keySelector, System::Collections::Generic::IComparer<TKey> ^ comparer);
public static System.Linq.IOrderedEnumerable<TSource> OrderBy<TSource,TKey> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,TKey> keySelector, System.Collections.Generic.IComparer<TKey> comparer);
public static System.Linq.IOrderedEnumerable<TSource> OrderBy<TSource,TKey> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,TKey> keySelector, System.Collections.Generic.IComparer<TKey>? comparer);
static member OrderBy : seq<'Source> * Func<'Source, 'Key> * System.Collections.Generic.IComparer<'Key> -> System.Linq.IOrderedEnumerable<'Source>
<Extension()>
Public Function OrderBy(Of TSource, TKey) (source As IEnumerable(Of TSource), keySelector As Func(Of TSource, TKey), comparer As IComparer(Of TKey)) As IOrderedEnumerable(Of TSource)

형식 매개 변수

TSource

source 요소의 형식입니다.

TKey

keySelector에서 반환하는 키의 형식입니다.

매개 변수

source
IEnumerable<TSource>

정렬할 값의 시퀀스입니다.

keySelector
Func<TSource,TKey>

요소에서 키를 추출하는 함수입니다.

comparer
IComparer<TKey>

키를 비교할 IComparer<T>입니다.

반환

요소가 키에 따라 정렬된 IOrderedEnumerable<TElement>입니다.

예외

source 또는 keySelectornull인 경우

설명

이 메서드는 지연 된 실행을 사용 하 여 구현 됩니다. 즉시 반환 값은 작업을 수행 하는 데 필요한 모든 정보를 저장 하는 개체입니다. 이 메서드가 나타내는 쿼리는 개체를 직접 호출 GetEnumerator 하거나 C# 또는 For Each Visual Basic에서 를 사용하여 foreach 개체를 열거할 때까지 실행되지 않습니다.

요소 자체의 값으로 시퀀스를 정렬하려면 에 대한 ID 함수(x => x C# 또는 Function(x) x Visual Basic의 경우)를 keySelector지정합니다.

이 메서드의 반환 형식인 형식 IOrderedEnumerable<TElement>을 확장하기 위해 두 가지 메서드가 정의됩니다. 이러한 두 메서드, 즉 ThenByThenByDescending를 사용하면 시퀀스를 정렬하는 추가 정렬 조건을 지정할 수 있습니다. ThenByThenByDescendingIOrderedEnumerable<TElement>또는 ThenByDescending 에 대한 연속 호출 ThenBy 수를 의미하며 를 반환합니다.

참고

는 에서 IEnumerable<T>상속되므로 IOrderedEnumerable<TElement> , ThenByOrderByDescending또는 에 대한 호출 결과에서 또는 ThenByDescendingOrderByDescending 를 호출 OrderByOrderBy수 있습니다. 이렇게 하면 이전에 설정된 순서를 무시하는 새 기본 순서가 도입됩니다.

가 이nullcomparer 기본 비교자를 Default 사용하여 키를 비교합니다.

이 메서드는 안정적인 정렬을 수행합니다. 즉, 두 요소의 키가 같으면 요소의 순서가 유지됩니다. 반면 불안정한 정렬은 키가 같은 요소의 순서를 유지하지 않습니다.

추가 정보

적용 대상