zoukankan      html  css  js  c++  java
  • java list集合元素根据某些字段排序

    一、jdk1.6的环境下

      新建ComparatorSort类,并实现Comparator接口,重写compare方法

      降序排序:o1的元素>o2的元素,并返回-1;o1的元素小于o2的元素,并返回1

      升序排序:o1的元素>o2的元素,并返回1;o1的元素小于o2的元素,并返回-1

      在方法中可对多个元素进行判断。

      

    import java.util.Comparator;
    
    import app.component.app.entity.AppProjectContRankVo;
    
    public class ComparatorSort implements Comparator<AppProjectContRankVo> {
    
        @Override
        public int compare(AppProjectContRankVo o1, AppProjectContRankVo o2) {
            if(o1.getOverdueRatio().compareTo(o2.getOverdueRatio())==1){
                return -1;
            }else if(o1.getOverdueRatio().compareTo(o2.getOverdueRatio())==-1){
                return 1;
            }else{
                return 0;
            }
        }
    }

    然后对需要排序的集合执行collections.sort

    Collections.sort(conBalCountByOrgNoList,new ComparatorSort());

    二、jdk1.8环境下

      可使用stream进行排序

     多条件排序使用:thenComparing
      降序排序使用:
    reversed()
    List<User> list = new ArrayList<User>();
            User user1 = new User();
            user1.setAge(19);
            user1.setScore(29);
            list.add(user1);
            User user2 = new User();
            user2.setAge(65);
            user2.setScore(322);
            list.add(user2);
            User user3 = new User();
            user3.setAge(19);
            user3.setScore(89);
            list.add(user3);
            List<User> listSort = list.stream().sorted(Comparator.comparing(User::getAge).reversed().thenComparing(User::getScore)).collect(Collectors.toList());
            for(User u:listSort){
                System.out.println(u.getAge()+"|"+u.getScore());
            }
  • 相关阅读:
    最容易懂的红黑树
    Chapter 9 (排序)
    【WC2013】糖果公园
    【Luogu1903】数颜色
    【笔记】Sigmoid函数
    【笔记】费马小定理、数论欧拉定理
    【笔记】单层感知机
    2020ICPC.小米 网络选拔赛第一场
    【Luogu3366】模板:最小生成树
    Codeforces Raif Round 1
  • 原文地址:https://www.cnblogs.com/linbky/p/12073870.html
Copyright © 2011-2022 走看看