zoukankan      html  css  js  c++  java
  • 集合List根据多个字段进行排序

     

            最近用java抓取数据的时候,遇到了需要对拿到的List集合按照多个字段进行排序。首先得让排序的实体类实现Comparable类并且重写它的compareTo方法,在compareTo中你可以自定义排序的规则。如果前者大于后者,则返回1,若果相等则返回0,若果前者小于后者,则返回-1;String字符串比较的时候也会经常用到这个compareTo方法,查看String类,可以看到它也实现了Comparable类。
    String类

     
    String类

    新建一个User类:按照id升序,age降序来排序。

    package com.entity;
    public class User implements Comparable<User>{
        private int id;
        private int age;
        private String name;
        public int getId() {
            return id;
        }
        public void setId(int id) {
            this.id = id;
        }
        public int getAge() {
            return age;
        }
        public void setAge(int age) {
            this.age = age;
        }
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
        
        public User(int id, int age, String name) {
            super();
            this.id = id;
            this.age = age;
            this.name = name;
        }
        @Override
        public int compareTo(User o) {
            // TODO Auto-generated method stub
            if(this.getId()>o.getId())
            {
                return 1;
            }else if(this.getId()<o.getId()){
                return -1;
            }else{
                if(this.getAge()>o.getAge()){
                    return -1;
                }else{
                    return 1;
                }
            }
        }
        
    }
    

    再建一个Junit测试类

    package com.test;
    import java.util.ArrayList;
    import java.util.Collections;
    import org.junit.Test;
    import com.entity.User;
    public class TestJunit {
        @Test
        public void test() {
            User u1=new User(1, 1, "A");
            User u2=new User(3, 2, "B");
            User u3=new User(3, 3, "C");
            User u4=new User(5, 4, "D");
            User u5=new User(5, 5, "E");
            ArrayList<User> list=new ArrayList<User>();
            list.add(u2);
            list.add(u5);
            list.add(u3);
            list.add(u4);
            list.add(u1);
            System.out.println("排序前:");
            for(int i=0;i<list.size();i++)
            {
                System.out.println("id:"+list.get(i).getId() +" age:"+list.get(i).getAge() +"  name:"+list.get(i).getName());
            }
            System.out.println("排序后:");
            //id升序,age降序排序
            Collections.sort(list);
            for(int i=0;i<list.size();i++)
            {
                System.out.println("id:"+list.get(i).getId() +" age:"+list.get(i).getAge() +"  name:"+list.get(i).getName());
            }
            System.out.println("");
        }
    
    }
    

    排序结果

     
    list排序后
  • 相关阅读:
    前端面试日更解答 interview-answe 1+1 2020-04-05
    Kafka学习系列----- 消费时序图
    JVM 垃圾回收算法简析
    ORM 框架选型对比
    Spring 中的设计模式之单例模式实现
    Synchroinzed 与lock 锁的区别
    Spring源码分析之ApplicationContextAware
    Springboot 启动简析
    HTTP/2.0 简单分析
    HTTPS 原理简要分析
  • 原文地址:https://www.cnblogs.com/shoshana-kong/p/14761429.html
Copyright © 2011-2022 走看看