Java 对象自定义排序
实现对集合中元素的排序,这个元素可以是一个对象。
两种方式:
- Comparable:内部比较器
- Comparator:外部比较器
1. Comparable,内部比较器
- 写在排序对象的内部
- 排序接口
-
一个实现了该接口的类,可以通过如下方法排序
- Collections.sort
- Arrays.sort
- 该接口只有一个compareTo方法
class Person implements Comparable<Person>{
private int age;
private String name;
...
@Override
public int compareTo(Person person) {
// 升序排列
return this.getAge()-person.getAge();;
}
}
2. Comparator,外部比较器
-
匿名内部类的方式,在list需要排序的时候,才具体定义排序的规则。
-
在java中,如果要对集合对象或数组对象进行排序,需要实现Comparator接口。
//Lambda简化Comparator接口匿名内部类写法
public static void main(String[] args) {
List<Student> ls = new ArrayList<>();
Student s1 = new Student("小明",25);
Student s2 = new Student("小黑",23);
Student s3 = new Student("小红",22);
Collections.addAll(ls,s1,s2,s3); //collections工具类
//按年龄排序
Collections.sort(ls, new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
// 升序
return o1.getAge() -o2.getAge();
}
});
System.out.println(ls);//[Student{name='小红', age=22}, Student{name='小黑', age=23}, Student{name='小明', age=25}]
//使用lambda简化
Collections.sort(ls,(Student o3, Student o4) ->{
return o3.getAge()-o4.getAge();
});
System.out.println(ls);
}
版权声明:本文为u010868192原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。