前言
在开发过程中,我们经常需要 根据列表中的元素的某个属性进行排序,下面我们将简单介绍常用的排序函数。
例如此处有一个类,拥有的元素为编号和值
public class Example
{
public int Number;
public int Value;
}
一、OrderBy、OrderByDescending、ThenBy、ThenByDescending
此时若我们想对此列表进行排序,将此类以编号为基准进行升序或者降序:
//默认此时已经有一个有元素的List<Example>名为ExampleList
ExampleList = ExampleList.OrderBy(classInfo => classInfo.Number).ToList();//升序
ExampleList = ExampleList.OrderByDescending(classInfo => classInfo.Number).ToList();//降序
这样我们就已经把此类以编号为基准进行了升序降序排列,若此时列表中有相同的编号,列表则会根据索引自动进行二次排列。但是若我们想通过自己的标准进行二次排列,例如按照Value的大小对此时的列表进行二次排列。则可以:
//二次升序排列
ExampleList = ExampleList.OrderBy(classInfo => classInfo.Number).ThenBy(classInfo => classInfo.Value).ToList();
//二次降序排列
ExampleList = ExampleList.OrderBy(classInfo => classInfo.Number).ThenByDescending(classInfo => classInfo.Value).ToList();
我们可以在升序或降序之后,再次进行多次的 ThenBy 或者是 ThenByDescending 来进行对一个类的不同属性的多次排列。
使用此方法对类型枚举筛选后再去筛选类型中的其他数值进行排序也是一种非常实用的方式,可以快速完成对列表的排列。
二、Sort
Sort 无返回值,直接对列表中的元素进行排序
ExampleList.Sort((x,y)=> { return x.Number.CompareTo(y.Number); });//升序排列
ExampleList.Sort((x,y)=> { return -x.Number.CompareTo(y.Number); });//降序排列
// 升序排序
ExampleList.Sort((arg1,arg2)=> {
//返回值含义:
//大于0:arg1放在arg2的后面
//等于0:保持当前的位置不变
//小于0:arg1放在arg2的前面
if (arg1.Number> arg2.Number){
return 1;
}else{
return -1;
}
});
// 先根据Number升序排序,如果Number相等,再按照Value进行降序排序
ExampleList.Sort((arg1,arg2)=> {
//返回值含义:
//大于0:arg1放在arg2的后面
//等于0:保持当前的位置不变
//小于0:arg1放在arg2的前面
if (arg1.Number > arg2.Number){
return 1;//升序
}else if (arg1.Number == arg2.Number){//若Number相等,再按照Value进行排序
if (arg1.Value > arg2.Value){
return -1;//降序
}else if (arg1.Value < arg2.Value ){
return 1;
}else{
return 0;
}
}else{
return -1;
}
});