现种方式。一是对象本身直接实现Comparable接口
另一种是借助比较器对象,这个比较器对象针对指定的类来定义。并实现Comparator接口
最后借助Conections.sort(),或ArrayList的sort()方来比较
Colections.sort(studentList, new Student.StudentComparator());
class Student implements Comparable{
private int age;
private String name;
//实现Comparable接口方法
public int compareTo(Object o){
Student s = (Object)o;
//当前对象的值大于被比较的对象值返回正数据,等于被比较对象的值返回0,小于被比较对象的值返回负数
return age>s.age ? 1 : (age=s.age ? 0 :-1);
}
}
另一种是借助比较器对象,这个比较器对象针对指定的类来定义。并实现Comparator接口
class Student{
private int age;
private String name;
//可以通过内部类实现一个类型的比较器
static class StudentComparator implements Comparator<Student>{
public int compare(Student s1, Student s2){
return s1.age>s2.age ? 1 : (s1.age=s2.age ? 0 : -1);
}
}
}
最后借助Conections.sort(),或ArrayList的sort()方来比较
Colections.sort(studentList, new Student.StudentComparator());
本文介绍了Java中两种常用的对象排序方法:一种是让对象自身实现Comparable接口,通过重写compareTo方法来实现;另一种是使用外部比较器Comparator,适用于不想修改类源码的情况。这两种方法都可用于Collections.sort()或ArrayList.sort()等集合排序操作。
6209

被折叠的 条评论
为什么被折叠?



