Esporta (0) Stampa
Espandi tutto
Il presente articolo è stato tradotto automaticamente. Passare il puntatore sulle frasi nell'articolo per visualizzare il testo originale. Ulteriori informazioni.
Traduzione
Originale

Metodo Enumerable.OrderByDescending<TSource, TKey> (IEnumerable<TSource>, Func<TSource, TKey>)

Ordina in senso decrescente gli elementi di una sequenza secondo una chiave.

Spazio dei nomi:  System.Linq
Assembly:  System.Core (in System.Core.dll)

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

Parametri di tipo

TSource

Tipo degli elementi di source.

TKey

Tipo della chiave restituita dall'oggetto keySelector.

Parametri

source
Tipo: System.Collections.Generic.IEnumerable<TSource>
Sequenza di valori da ordinare.
keySelector
Tipo: System.Func<TSource, TKey>
Funzione per estrarre una chiave da un elemento.

Valore restituito

Tipo: System.Linq.IOrderedEnumerable<TSource>
Oggetto IOrderedEnumerable<TElement> i cui elementi vengono ordinati in senso decrescente in base a una chiave.

Nota sull'utilizzo

In Visual Basic e C# è possibile chiamare questo metodo come metodo di istanza su qualsiasi oggetto di tipo IEnumerable<TSource>. Per chiamare il metodo utilizzando la sintassi del metodo di istanza, omettere il primo parametro. Per ulteriori informazioni, vedere Metodi di estensione (Visual Basic) o Metodi di estensione (Guida per programmatori C#).

EccezioneCondizione
ArgumentNullException

source o keySelector è null.

Questo metodo viene implementato tramite esecuzione posticipata. Il valore restituito immediato è un oggetto che contiene tutte le informazioni necessarie all'esecuzione dell'azione. La query rappresentata da questo metodo non viene eseguita finché l'oggetto non viene enumerato tramite chiamata diretta al relativo metodo GetEnumerator o utilizzando l'oggetto foreach in Visual C# oppure For Each in Visual Basic.

Per ordinare una sequenza in base ai valori degli stessi elementi, specificare la funzione di identità (x => x in Visual C# o Function(x) x in Visual Basic) per keySelector.

Per un esempio di questo metodo, vedere OrderByDescending<TSource, TKey>(IEnumerable<TSource>, Func<TSource, TKey>, IComparer<TKey>).

Vengono definiti due metodi per estendere il tipo IOrderedEnumerable<TElement>, che costituisce il tipo restituito da questo metodo. Questi due metodi, ovvero ThenBy e ThenByDescending, consentono di specificare criteri di ordinamento aggiuntivi per ordinare una sequenza. ThenBy e ThenByDescending restituiscono inoltre un oggetto IOrderedEnumerable<TElement> che indica che è possibile eseguire un qualsiasi numero di chiamate consecutive a ThenBy o ThenByDescending.

NotaNota

IOrderedEnumerable<TElement> eredita da IEnumerable<T>, pertanto è possibile chiamare OrderBy o OrderByDescending sui risultati di una chiamata a OrderBy, OrderByDescending, ThenBy o ThenByDescending. Tale operazione introduce un nuovo ordinamento primario che ignora l'ordinamento stabilito in precedenza.

In questo metodo i valori vengono confrontati utilizzando l'operatore di confronto uguaglianze predefinito Default.

Questo metodo esegue un ordinamento stabile: vale a dire che l'ordine degli elementi con chiavi uguali viene mantenuto. Un ordinamento instabile al contrario non mantiene l'ordine di elementi che presentano la stessa chiave.

Nella sintassi di una espressione di query, una clausola orderby descending (Visual C#) o Order By Descending (Visual Basic) viene convertita in una chiamata di OrderByDescending.

.NET Framework

Supportato in: 4.5.2, 4.5.1, 4.5, 4, 3.5

.NET Framework Client Profile

Supportato in: 4, 3.5 SP1

Libreria di classi portabile

Supportato in: Libreria di classi portabile

.NET per applicazioni Windows Store

Supportato in: Windows 8

.NET per applicazioni Windows Phone

Supportato in: 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 (ruoli di base del server non supportati), Windows Server 2008 R2 (ruoli di base del server supportati con SP1 o versione successiva, Itanium non supportato)

.NET Framework non supporta tutte le versioni di ciascuna piattaforma. Per un elenco delle versioni supportate, vedere Requisiti di sistema di .NET Framework.

Aggiunte alla community

AGGIUNGI
Mostra:
© 2014 Microsoft