对List中的对象按某个字段进行排序

这个是参考了其他博主写的文章

原文链接:https://blog.csdn.net/juligang320/article/details/82885738#commentBox

这在自己的博客,进行了稍微的更新,以便记录自己的学习过程

实体对象

public class Logs implements Serializable, Comparable<Logs> {

    private String id;
    private String username;
    private String contents;
    private String consequence;
    private String ip;
    private Long times;

    @Override
    public int compareTo(Logs o) {
        return 0;
    }

}

解析: Logs实体,要继承Comparable<T>接口, 然后再实现一个public int compareTo(Logs o) 方法.

现在,我要对List<Logs> 中的数据按 times 字段进行排序

    @Test
    public void testMath(){
        List<Logs> list = new ArrayList<Logs>();
        list.add(new Logs("1","chen", "djifand", "jdifa", "jdfid", 49L));
        list.add(new Logs("134","ce", "cae", "jdifa", "jdfid", 123L));
        list.add(new Logs("3","cet", "djifand", "jdifa", "jdfid", 99L));
        list.add(new Logs("4","egge", "djifand", "jdifa", "jdfid", 111L));
        list.add(new Logs("15","chen", "djifand", "jdifa", "jdfid", 59L));
        list.add(new Logs("6","chen2", "cae", "jdifa", "jdfid", 123L));
        list.add(new Logs("87","cet", "djifand", "jdifa", "jdfid", 213L));
        list.add(new Logs("8","egge", "djifand", "jdifa", "jdfid", 201L));
        list.add(new Logs("9","egge2", "djifand", "jdifa", "jdfid", 269L));
        list.add(new Logs("10","ce", "cae", "jdifa", "jdfid", 121L));
        list.add(new Logs("11","chen3", "djifand", "jdifa", "jdfid", 1123L));
        list.add(new Logs("5","cet2", "djifand", "jdifa", "jdfid", 12L));

        System.out.println("---- 排序前的输出  ----- ");
        for (Logs logs : list) {
            System.out.println("数据: "+logs);
        }
        System.out.println("---- 排序后的结果  ----- ");
        List<Logs> search = search(list);

        for (Logs logs : search) {
            System.out.println("-->"+logs);
        }

    }


     // 方式1: 降序排列
     public List<Logs> search(List<Logs> logsList){
        Collections.sort(logsList, new Comparator<Logs>() {
            @Override
            public int compare(Logs o1, Logs o2) {
                if ((o1.getTimes() > o2.getTimes())){
                    return -1;
                }
                if (o1.getTimes() == o2.getTimes()){
                    return 0;
                }
                return 1;
            }
        });
        return logsList;
    }

     // 方式2: 升序排列
     public List<Logs> search(List<Logs> logsList){
        Collections.sort(logsList, new Comparator<Logs>() {
            @Override
            public int compare(Logs o1, Logs o2) {
                if ((o1.getTimes() > o2.getTimes())){
                    return 1;
                }
                if (o1.getTimes() == o2.getTimes()){
                    return 0;
                }
                return -1;
            }
        });
        return logsList;
    }
    // 方式3: 降序排列 
    public List<Logs> search(List<Logs> logsList){
        Collections.sort(logsList, new Comparator<Logs>() {
            @Override
            public int compare(Logs o1, Logs o2) {
                return -o1.getTimes().compareTo(o2.getTimes());
            }
        });
        return logsList;
    }

    // 方式4: 升序排列
    public List<Logs> search(List<Logs> logsList){
        Collections.sort(logsList, new Comparator<Logs>() {
            @Override
            public int compare(Logs o1, Logs o2) {
                return o1.getTimes().compareTo(o2.getTimes());
            }
        });
        return logsList;
    }

至此,List<Logs> 里面的Long数据类型比较完毕.

  • 0
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值