Comparable : 对实现它的每个类的对象进行整体排序。若一个类实现 Comparable 接口,实现 Comparable 接口的类的对象的 List 列表 (或数组) 可以通过 Collections.sort (或 Arrays.sort) 进行排序。此外,实现 Comparable 接口的类的对象可以用作 “有序映射(如TreeMap)” 中的键或 “有序集合(TreeSet)” 中的元素,而不需要指定比较器
# Comparable 源码
package java.lang;
import java.util.*;
public interface Comparable<T> {
public int compareTo(T o);
}
# 实例
public class Person1 implements Comparable<Person1> {
private int age;
private String name;
public Person1(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public int compareTo(Person1 o) {
return this.age-o.age;
}
@Override
public String toString() {
return name+":"+age;
}
public static void main(String[] args) {
Person1 person1 = new Person1("zzh",18);
Person1 person2 = new Person1("jj",17);
Person1 person3 = new Person1("qq",19);
List<Person1> list = new ArrayList<>();
list.add(person1);
list.add(person2);
list.add(person3);
System.out.println(list);
Collections.sort(list);
System.out.println(list);
}
}
对于对类已经固定,无法进行对其类自身的修改,同时也用 final 进行修饰,不准继承 Comparable 接口,此时就可以在类的外部使用 Comparator
# Comparator 源码
package java.util;
public interface Comparator<T> {
int compare(T o1, T o2);
boolean equals(Object obj);
}
# 实例
Person2 p1 = new Person2("zzh",18);
Person2 p2 = new Person2("jj",17);
Person2 p3 = new Person2("qq",19);
List<Person2> list2 = new ArrayList<Person2>();
list2.add(p1);
list2.add(p2);
list2.add(p3);
System.out.println(list2);
Collections.sort(list2,new Comparator<Person2>() {
@Override
public int compare(Person2 o1, Person2 o2) {
if(o1 == null || o2 == null) {
return 0;
}
return o1.getAge()-o2.getAge();
}
});
System.out.println(list2);
在进行对类比较的时候,尽量使用 Comparable接口,一旦实现 Comparable接口,它就可以跟许多泛型算法以及依赖于改接口的集合实现进行协作。