Comparable接口可能是java里面最简单的一个接口了,其源码只有一个方法
public interface Comparable<T> {
public int compareTo(T o);
}
上面就是Comparable的源码
他的API解释:
此接口强行对实现它的每个类的对象进行整体排序。这种排序被称为类的自然排序,类的 compareTo 方法被称为它的自然比较方法。
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class Person implements Comparable<Person> {
private String name;
private Integer age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
private Person(String name, Integer age) {
this.name = name;
this.age = age;
}
@Override
public int compareTo(Person o) {
return this.age-o.age;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
public static void main(String[] args) {
List<Person> personList=new ArrayList<>();
Person p1=new Person("张三",23); Person p2=new Person("李四",12); Person p3=new Person("王五",45);
personList.add(p1); personList.add(p2); personList.add(p3);
System.out.println(personList);
Collections.sort(personList);
System.out.println(personList);
}
}
重点来了
但是我们在实际开发中很少用得到这个,就觉得它没有什么作用
其实用处还是有的!!!
第一: 这个知识点解释了为什么数组和集合能够进行排序。
第二: 实际开发中基本上不需要重写改该接口。但是对于特定的实现,可能用到这些知识点。比如我存入集合类中一些对象,这些对象是你自己自定义的。现在你希望通过某个字段排序后,添加到数据库,这时你就可以将自己定义的类实现这个接口了,而不需要手动去排序了。