다음을 통해 공유


Enumerable.ThenByDescending 메서드

정의

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

오버로드

ThenByDescending<TSource,TKey>(IOrderedEnumerable<TSource>, Func<TSource,TKey>)

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

ThenByDescending<TSource,TKey>(IOrderedEnumerable<TSource>, Func<TSource,TKey>, IComparer<TKey>)

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

ThenByDescending<TSource,TKey>(IOrderedEnumerable<TSource>, Func<TSource,TKey>)

Source:
OrderBy.cs
Source:
OrderBy.cs
Source:
OrderBy.cs

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

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

형식 매개 변수

TSource

source 요소의 형식입니다.

TKey

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

매개 변수

source
IOrderedEnumerable<TSource>

정렬할 요소가 들어 있는 IOrderedEnumerable<TElement>입니다.

keySelector
Func<TSource,TKey>

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

반환

요소가 키에 따라 내림차순으로 정렬된 IOrderedEnumerable<TElement>입니다.

예외

source 또는 keySelectornull인 경우

설명

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

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

ThenByThenByDescending 는 이러한 메서드의 반환 형식이기도 한 형식 IOrderedEnumerable<TElement>을 확장하도록 정의됩니다. 이 디자인을 사용하면 여러 ThenBy 개 또는 ThenByDescending 메서드를 적용하여 여러 정렬 조건을 지정할 수 있습니다.

참고

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

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

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

C# 쿼리 식 구문에서 절은 orderby [first criterion], [second criterion] descending 의 호출 ThenByDescending로 변환됩니다.

Visual Basic 쿼리 식 구문에서 절은 Order By [first criterion], [second criterion] Descending 호출로 ThenByDescending변환됩니다.

추가 정보

적용 대상

ThenByDescending<TSource,TKey>(IOrderedEnumerable<TSource>, Func<TSource,TKey>, IComparer<TKey>)

Source:
OrderBy.cs
Source:
OrderBy.cs
Source:
OrderBy.cs

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

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

형식 매개 변수

TSource

source 요소의 형식입니다.

TKey

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

매개 변수

source
IOrderedEnumerable<TSource>

정렬할 요소가 들어 있는 IOrderedEnumerable<TElement>입니다.

keySelector
Func<TSource,TKey>

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

comparer
IComparer<TKey>

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

반환

요소가 키에 따라 내림차순으로 정렬된 IOrderedEnumerable<TElement>입니다.

예외

source 또는 keySelectornull인 경우

예제

다음 코드 예제에서는 사용자 지정 비교자를 사용 하 여 ThenByDescending<TSource,TKey>(IOrderedEnumerable<TSource>, Func<TSource,TKey>, IComparer<TKey>) 내림차순으로 시퀀스에서 요소의 보조 순서를 수행 하는 방법을 보여 줍니다.

public class CaseInsensitiveComparer : IComparer<string>
{
    public int Compare(string x, string y)
    {
        return string.Compare(x, y, true);
    }
}

public static void ThenByDescendingEx1()
{
    string[] fruits = { "apPLe", "baNanA", "apple", "APple", "orange", "BAnana", "ORANGE", "apPLE" };

    // Sort the strings first ascending by their length and
    // then descending using a custom case insensitive comparer.
    IEnumerable<string> query =
        fruits
        .OrderBy(fruit => fruit.Length)
        .ThenByDescending(fruit => fruit, new CaseInsensitiveComparer());

    foreach (string fruit in query)
    {
        Console.WriteLine(fruit);
    }
}

/*
    This code produces the following output:

    apPLe
    apple
    APple
    apPLE
    orange
    ORANGE
    baNanA
    BAnana
*/
' This class provides a custom implementation of the Compare() method.
Class CaseInsensitiveComparer
    Implements IComparer(Of String)

    Function Compare(ByVal x As String, ByVal y As String) As Integer _
    Implements IComparer(Of String).Compare

        ' Compare values and ignore case.
        Return String.Compare(x, y, True)
    End Function
End Class

Sub ThenByDescendingEx1()
    Dim fruits() As String =
    {"apPLe", "baNanA", "apple", "APple", "orange", "BAnana", "ORANGE", "apPLE"}

    ' Sort the strings first by their length and then
    ' by using a custom "case insensitive" comparer.
    Dim query As IEnumerable(Of String) =
    fruits _
    .OrderBy(Function(fruit) fruit.Length) _
    .ThenByDescending(Function(fruit) fruit, New CaseInsensitiveComparer())

    ' Display the results.
    Dim output As New System.Text.StringBuilder
    For Each fruit As String In query
        output.AppendLine(fruit)
    Next
    Console.WriteLine(output.ToString())
End Sub

' This code produces the following output:

' apPLe
' apple
' APple
' apPLE
' orange
' ORANGE
' baNanA
' BAnana

설명

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

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

ThenByThenByDescending 는 이러한 메서드의 반환 형식이기도 한 형식 IOrderedEnumerable<TElement>을 확장하도록 정의됩니다. 이 디자인을 사용하면 여러 ThenBy 개 또는 ThenByDescending 메서드를 적용하여 여러 정렬 조건을 지정할 수 있습니다.

참고

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

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

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

적용 대상