首先可以回答,java在集合中比较对象的接口主要有两个
- Comparable 接口 : 自己和自己比较
- Comparator 接口: 第三方比较器,需要在排序的自己定义
下面详细介绍上面的两个接口:
Comparable 接口
Comparable 接口主要是用来定义排序的,用法主要为,需要排序的对象要实现这个接口,
此接口有唯一的方法。
也就是说,一个对象如果想要排序,则需要实现此接口。实现此接口的对象可以在Collections.sort 或
者 Arrays.sort 中进行排序。
T 是泛型,表示可以与此对象进行比较的对象。
为什么需要T泛型呢??
答: 主要是加上泛型限定,在编译阶段就可以发现传入的参数是不是需要 比较的对象,
就不需要在运行时期进行类型检
测试结果为:
如果Person 类是第三方的jar包里的类,且没有实现排序功能,而且又不能去该jar里的类。
那我们如何实现排序呢? 这时 Comparator 接口就要上场了,下面介绍 Comparator 接口。
Comparator 接口
该接口定义如下:
下面我们再次实现 Person 按照年龄排序,但此时 Person 不是先任何接口:
代码如下:实现Person 按照年龄倒序
结果如下:
总结
- Comparable
- 自己和自己比较,需要实现Comparable 接口
- 比较的方法: compareTo 方法
- 在JDK 中典型的应用: TreeSet 中的排序
- Comparator
- 第三方比较器
- 比较方法: compare
- 在JDK中的应用: Arrays.sort
- 如果我们需要控制某个类的顺序,而从类本身又不支持排序且不能对类做任何修改,这是可以用此比较器