这取决于您是要对列表本身进行排序,还是按排序顺序检索值(不更改列表)。
对列表本身进行排序(假设您有一个名为elements 的List<element>):
elements.Sort((x, y) => x.priority.CompareTo(y.priority));
// now elements is sorted
.NET 2.0 等效:
elements.Sort(
delegate(element x, element y) {
return x.priority.CompareTo(y.priority);
}
);
按排序顺序获取值:
var orderedElements = elements.OrderBy(x => x.priority);
// elements remains the same, but orderedElements will retrieve them in order
.NET 2.0 中没有等效的 LINQ,但您可以编写自己的:
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;
}
用法:
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);