第一种,List对象实现Comparable接口
先写一个User类,实现Comparable接口,泛型为User
public class User implements Comparable<User> {
private String name;
private Integer number;//学号 (排序的字段注意要用包装类)
private Integer age;//年龄
public User(String name, Integer number, Integer age) {
this.name = name;
this.number = number;
this.age = age;
}
//......set和get方法
//重写compareTo()方法,注意用该方法需要包装类,所以字段不能定义为基本数据类型,如int
@Override
public int compareTo(User user) {//通过学号排序
return this.getNumber().compareTo(user.getNumber());
}
}
在main函数里list添加两个对象,然后调用Collections.sort()方法
public static void main(String[] args) {
User u1 = new User("Dawa", 3);
User u2 = new User("Erwa", 2);
List<User> userList = new ArrayList<>();
userList.add(u1);
userList.add(u2);
Collections.sort(userList);//对list排序,User类固定写为学号,所以按照学号排序
for (User user : userList) {
System.out.println(user.getName());
}
}
结果:
Erwa
Dawa
第二种,重载Collections.sort方法
User类不需要实现Comparable接口和方法,将Collections.sort(userList);
替换为重载方法,此处可以动态更改需要按照哪个字段排序
Collections.sort(userList, new Comparator<User>() {
@Override
public int compare(User user, User t1) {
return user.getOrder().compareTo(t1.getOrder());
}
});
结果不变
总结:第一种方法简单,但是排序字段固定,第二种较为灵活。