Questo dipende se si desidera ordinare l'elenco stesso o recuperare i valori in ordine (senza modificare l'elenco).
Per ordinare l'elenco stesso (supponendo di avere un List<element>
chiamato elements
):
elements.Sort((x, y) => x.priority.CompareTo(y.priority));
// now elements is sorted
NET 2.0 equivalenti:
elements.Sort(
delegate(element x, element y) {
return x.priority.CompareTo(y.priority);
}
);
per ottenere i valori in modo ordinato:
var orderedElements = elements.OrderBy(x => x.priority);
// elements remains the same, but orderedElements will retrieve them in order
Non c'è un equivalente LINQ in .NET 2.0, ma è possibile scrivere il proprio:
public static IEnumerable<T> OrderBy<T>(IEnumerable<T> source, Comparison<T> comparison) {
List<T> copy = new List<T>(source);
copy.Sort(comparison);
foreach (T item in copy)
yield return item;
}
Usage:
Comparison<element> compareByPriority = delegate(element x, element y) {
return x.priority.CompareTo(y.priority);
};
// unfortunately .NET 2.0 doesn't support extension methods, so this has to be
// expressed as a regular static method
IEnumerable<element> orderedElements = OrderBy(elements, compareByPriority);
fonte
2010-03-24 17:37:47
Quale linguaggio di programmazione? –
C#? Giava? Che lang? –
probabilmente C#, a causa della sintassi <> generica/template, C++ non ha niente di incorporato chiamato esattamente 'List', e Java preferirebbe ArrayList. –