zoukankan      html  css  js  c++  java
  • 对List集合中的对象进行按某个属性排序

    最近在实际的开发工作中,碰到排序的问题,如题,我们如何针对List集合中的某一个属性进行排序

    参考:https://blog.csdn.net/qq_39366175/article/details/79449178

    这里先举一个简单的例子:

    复制代码
    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.List;
    
    /**
     * Created by IntelliJ IDEA
     * 这是一个神奇的Class
     *
     * @author zhz
     * @date 2019/9/25 10:37
     */
    public class DemoTest {
        public static void main(String[] args) {
    
    
            List<String> list1 = new ArrayList<>();
            list1.add("3");
            list1.add("4");
            list1.add("1");
            list1.add("2");
            list1.add("f");
            list1.add("a");
            System.out.println("排序前--:"+list1.toString());
            Collections.sort(list1);
            System.out.println("排序前后--:"+list1.toString());
    
    
        }
    }
    复制代码

    打印结果如下:

     可以总结为,加单的String类型的排序,是排数字,再排字母,默认排序方式是升序。

    下面言归正传,要是一个List中存的是某种对象,该对象有多种属性,那么如何进行升序或者降序排序呢?

    这个时候我们就会进行一系列猛如虎的操作,结果有可能会遇到下面这种坑:

     这时候你可能会问那我们怎么搞啊:

    下面首先我们先创建一个测试用类,这里重点说一哈,可以实现一个Comparable接口重写compareTo

    复制代码
    /**
     * Created by IntelliJ IDEA
     * 这是一个神奇的Class
     *
     * @author zhz
     * @date 2019/9/25 10:49
     */
    public class TestA implements Comparable<TestA> {
        private String name;
    
        private Integer age;
    
        public TestA(String name, Integer age) {
            super();
            this.name = name;
            this.age = age;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public Integer getAge() {
            return age;
        }
    
        public void setAge(Integer age) {
            this.age = age;
        }
    
        @Override
        public String toString() {
            return "TestA [name=" + name + ", age=" + age + "]";
        }
    
        @Override
        public int compareTo(TestA o) {
            return this.age.compareTo(o.getAge());
        }
        
    }
    复制代码

    我们就可以进行下一步的检验结果的操作了

    复制代码
    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.Comparator;
    import java.util.List;
    
    /**
     * Created by IntelliJ IDEA
     * 这是一个神奇的Class
     *
     * @author zhz
     * @date 2019/9/25 10:37
     */
    public class DemoTest {
        
        public static void main(String[] args) {
    
            TestA testA1 = new TestA("老张", 3);
            TestA testA2 = new TestA("老李", 1);
            TestA testA3 = new TestA("老王", 2);
            List<TestA> list  = new ArrayList<>();
            list.add(testA1);
            list.add(testA2);
            list.add(testA3);
            System.out.println("排序前--:"+list.toString());
            Collections.sort(list, new Comparator<TestA>() {
                @Override
                public int compare(TestA o1, TestA o2) {
                    //升序
                    return o1.getAge().compareTo(o2.getAge());
                }
            });
            System.out.println("升序排序后--:"+list.toString());
    
            Collections.sort(list, new Comparator<TestA>() {
                @Override
                public int compare(TestA o1, TestA o2) {
                    //降序
                    return o2.getAge().compareTo(o1.getAge());
                }
            });
            System.out.println("降序排序后--:"+list.toString());
    
        }
    
    }
    复制代码

    输出的是啥:

    附:本文大部分参考网上资源,主要用于个人的笔记心得记录

    下面是个人在处理业务中的使用:

    到了这里你觉得很神奇?错了,现在是java8的时代,我们来看看新特性下如何排序的:

    List<CountCardDetailVo> all = new ArrayList<>();
    //根据创建时间降序排序
    all.sort(Comparator.comparing(CountCardDetailVo::getCreateTime).reversed());
    //根据创建时间升序排序
    all.sort(Comparator.comparing(CountCardDetailVo::getCreateTime));

    是不是很简单,很奇迹,很强大~~

  • 相关阅读:
    python移动文件
    python分割多个分隔符
    pywintypes.com_error: (-2147418111, '被呼叫方拒绝接收呼叫。', None, None)
    MySQL查看和修改字符集的方法
    Django创建超级管理员用户
    P2567.[SCOI2009] windy 数(数位DP)
    920G.List of Integers(莫比乌斯函数+二分)
    916E.Jamie and Tree (倍增LCA+线段树维护DFS序)
    GYM100376F.Circle and Trees(树形DP+倍增LCA)
    GYM100376E.LinearMapReduce(线段树维护矩阵乘法)
  • 原文地址:https://www.cnblogs.com/wuwuyong/p/14699470.html
Copyright © 2011-2022 走看看