Comparable和Comparator的区别
1、相同点:都是java.util包下的接口,都是用来做比较的
2、不同点:
-
Comparable
可以认为是内比较器,如果一个类实现了Comparable接口,就意味着该类支持排序,可以通过Collections.sort和
Arrays.sort进行排序
如果add到Collection的对象想要Collections.sort()进行自动排序的话,那么这个对象必须实现Comparable接口,
使用其compareTo方法compareTo(Object o)方法分析:
@Override public int compareTo(Object o) { Girl g = (Girl)o; return this.age - g.getAge(); }
Int compareTo(Object o)方法分析:
返回值是int,返回结果有三种情况:
1、比较者大于被比较者(也就是compareTo方法里面的对象),那么返回正整数
2、比较者等于被比较者,那么返回0
3、比较者小于被比较者,那么返回负整数
方法体中就是定义按照的属性进行排序• Comparator
Comparator可以认为是一个外比较器,如果我们需要控制某个类的次序,而该类本身不支持排序(就是没有实现Comparable接口),那么,我们可以自己建立一个类比较器来进行排序。那个类只需要实现Comparator接口,然后重
写接口中的compare()Int compare(Object o1,Object o2) 返回参数是int型的,返回结果有三种情况: 1、o1大于o2,返回正整数 2、o1等于o2,返回0 3、o1小于o3,返回负整数
总结:
Comparable是排序接口;若一个类实现了Comparable接口,就意味着“该类支持排序”。
而Comparator是比较器;我们若需要控制某个类的次序,可以建立一个“该类的比较器”来进行排序。
如果实现类没有实现Comparable接口,但是又想对两个类进行比较(或者实现类实现了Comparable接口,但是对compareTo方法内的比较算法不满意),那么可以实现Comparator接口,自定义一个比较器,重写compare方法