今天在工作中遇到一个状况,一个骑乘列表list (List<HorseDate> list = new List<HorseDate>())
列表的排序规则优先级:
1.首先按照骑乘等级降序排序
2.其实按照骑乘上阵等级降序排列
3.再次按照骑乘品质降序排列
4.最后按照骑乘ID降序排列
下午考虑了一下,觉得头大了,就索性睡了一觉,结果在梦中来了灵感!!!(看来以后遇到困难的问题得先睡觉啦)
言归正传:
已知条件是一个是horseList列表, 一个是HorseDate类
接下来就是见证奇迹的时刻:
其实原理很简单list本身含sort方法,并支持自定义排序规则
private int SortByID(HorseDate a1, HorseDate a2)
{
if (a1.level.CompareTo(a2.level) != 0)
return -(a1.level.CompareTo(a2.level));
else if (a1.ToLevel.CompareTo(a2.ToLevel) != 0)
return -(a1.ToLevel.CompareTo(a2.ToLevel));
else if (a1.Quality.CompareTo(a2.Quality) != 0)
return -(a1.Quality.CompareTo(a2.Quality));
else if (a1.ID.CompareTo(a2.ID) != 0)
return -(a1.ID.CompareTo(a2.ID));
else
return 1;
}
程序中直接调用
horseList,.Sort(SortByID);
最后,有人注意到为什么return返回的降序吗?哈哈,因为前面提到过这个功能是要按照降序排列的,所以前面需要加负号,如果是升序排列就不需要了