Esto depende de si desea ordenar la lista o recuperar los valores en orden ordenado (sin cambiar la lista).
Para ordenar la lista en sí (suponiendo que tiene una llamada List<element>
elements
):
elements.Sort((x, y) => x.priority.CompareTo(y.priority));
// now elements is sorted
.NET 2.0 equivalentes:
elements.Sort(
delegate(element x, element y) {
return x.priority.CompareTo(y.priority);
}
);
para obtener los valores en el orden establecido:
var orderedElements = elements.OrderBy(x => x.priority);
// elements remains the same, but orderedElements will retrieve them in order
No hay equivalente LINQ en .NET 2.0, pero puede escribir el suyo:
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;
}
Uso:
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);
¿Qué lenguaje de programación? –
C#? ¿Java? ¿Qué Lang? –
probablemente C#, debido a la <> sintaxis genérica/plantilla, C++ no tiene nada incorporado llamado exactamente 'Lista', y Java preferiría ArrayList. –