最近用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(""