Java中为我们提供了两种比较机制:Comparable和Compatator,二者都是用来实现对象的比较、排序。
Comparable
Comparable是一个内比较器,实现了Comparable接口的类有一个特点,就是这些类是可以和自己比较的,至于具体和另一个实现了Comparable接口的类如何比较,则依赖comparaTo方法的实现。
自定义对象要进行排序需要继承Comparable接口,并重写了compareTo方法。只有继承了Comparable接口并重写了compareTo方法,这个类才视为Comparable类,如果只重写了compareTo方法,没有明确implement Comparable则只是一个普通的类。
Comparator
Comparator接口里面有一个compare方法,方法有两个参数T o1和T o2,是泛型的表达方式,分别表示待比较的两个对象,方法的返回值为int型。
因为泛型指定死了,所以实现Comparator接口的实现类只能是两个相同的对象进行比较,实现Comparator接口的实现类一般都会以待比较的实体类+Comparator
来命名。
两者的区别
实现Comparable接口的方式比实现Comparator接口的耦合度要强一些,如果要修改比较算法,要修改Comparable接口的实现类,而实现Comparator的类是在外部进行比较的,不需要对实现类有任何修改。因此:
- 对于一些普通的数据类型,他们默认实现了Comparable接口,实现了compareTo方法,可以直接使用。
- 对于一些自定义类,他们可能在不同情况下需要实现不同的比较策略,我们可以创建Comparator接口,然后使用特定的Comparator实现进行比较。
不同之处:
- Comparator位于java.util包下,而Comparable位于java.lang包下
- 实现Comparable接口的方式比实现Comparator接口的耦合性要强
感谢并参考:
https://mp.weixin.qq.com/s/h1mhn32kKI86IcFCgjWPVA