一.需求
IP池根据批量和触发分为两列
每列根据地理位置进行分组(组与组根据地理位置添加的时间排列,地理位置添加越早,摆放的越靠上),组内根据0级-最高级的单用池和0级-最高级的复用池 由上往下排列
二:分析
多维度排序:按要求,排序的优先级有三个(也就是三个维度);
第一维度:地理位置添加的时间 (添加时间越早排序越靠前,添加时间相同,则比较第二、三维度)
第二维度:单用池和复用池(单用池排在复用池前,名称相同,则比较第三维度)
第三维度:等级(由低往高排)
三:实现
核心代码,比较器
public class ComparatorResultTypeUtil implements Comparator{
public int compare(Object arg0, Object arg1) {
Pool desc0=(Pool)arg0;
Pool desc1=(Pool)arg1;
//首先比较第一维度,如果相同,则比较第二指标
int flag=desc0.getLocationCreatTime().compareTo(desc1.getLocationCreatTime());
if(flag==0){
//第二维度,若相同,则比较第三维度
int flag2 = desc0.getPoolClass().compareTo(desc1.getPoolClass());
if(flag2==0){
return desc0.getPoolLevel().compareTo(desc1.getPoolLevel());
}else {
return flag2;
}
}else{
return flag;
}
}
}
controller中的调用
ComparatorResultTypeUtil comparator=new ComparatorResultTypeUtil();
if(CollectionUtils.isNotEmpty(triggerPoolList)){
Collections.sort(triggerPoolList, comparator);
model.addAttribute("triggerPoolList", triggerPoolList);
}
四:效果
五:总结
本例是同一个对象中三个属性的排序,比较器可以根据实际需求的维度灵活改变,理论上支持对象中所有属性排序
java 8新特性 使用lambda表达式,可以实现多维度链式排序,比上述方法简洁。但 项目比较老,jdk用的是1.8,但spring的版本较低,对jdk1.8的新特性支持不够友好。最后用这种原始的方法