对List进行Collections.sort()自定义排序遇到了一些问题。
自定义排序规则:0放在最后面,签名的都是从小到大排序。本人的代码实现了该功能,但总感觉不是最佳的办法,求大佬指教。
private static List sortLostValueList( List listLost ){
List<Integer> playCode = new ArrayList<>();
for(int i =0;i<listLost.size();i++){
playCode.add( Integer.valueOf( listLost.get(i).getPlayCode() ));
}
System.out.println("排序之前"+JacksonUtil.java2json(playCode));
Collections.sort(playCode,new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2) {
if( o1 == 0 ){
return 0;
}
return -1;
}
});
System.out.println("第一遍排序"+JacksonUtil.java2json(playCode));
Collections.sort(playCode,new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2) {
if( o1 == 0 ){
return 0;
}
return o1-o2;
}
});
System.out.println("第二遍排序:"+JacksonUtil.java2json(playCode));
//把所有有关0的都放在最后面
return listLost;
}
使用lamda表达式简化
public static void main(String[] args) {
List<Integer> playCode = new ArrayList<>(Arrays.asList(9310, 9311, 9320, 9318, 0, 9340, 0, -1));
System.out.println("排序之前:" + Arrays.toString(playCode.toArray()));
playCode.sort((o1, o2) -> {
if (o1 == 0) {
return 1;
}
if (o2 == 0) {
return -1;
}
return o1 - o2;
});
System.out.println("排序之后:" + Arrays.toString(playCode.toArray()));
}
使用 Collections.sort 方法是需要提供一个 Comparator 的实现类的,看输出结果是升序排列的,如果想降序可以返回 o2-o1。
排序也就是这两种方式。
可以自定义一个比较器,然后对对象进行排序比较,如:http://www.java265.com/JavaJingYan/202203/16485461582619.html