转载自
https://www.cnblogs.com/xujian2014/p/5215082.html
https://www.cnblogs.com/szlbm/p/5504634.html
Comparable和Comparator区别比较
Comparable是排序接口,若一个类实现了Comparable接口,就意味着“该类支持排序”。而Comparator是比较器,我们若需要控制某个类的次序,可以建立一个“该类的比较器”来进行排序。若类实现了Comparable接口,则针对该类的集合可以直接调用 Collections.sort(和 Arrays.sort)进行自动排序。
Comparable相当于“内部比较器”,而Comparator相当于“外部比较器”。
两种方法各有优劣:
- 用Comparable 简单, 只要实现Comparable 接口的对象直接就成为一个可以比较的对象,但是需要修改源代码。
- 用Comparator 的好处是不需要修改源代码, 而是另外实现一个比较器, 当某个自定义的对象需要作比较的时候,把比较器和对象一起传递过去就可以比大小了, 并且在Comparator 里面用户可以自己实现复杂的可以通用的逻辑,使其可以匹配一些比较简单的对象,那样就可以节省很多重复劳动了。
个人总结:主要差异看其接口方法,如下表。
接口名 | 接口方法 | 方法说明 |
---|---|---|
Comparator | int compare(T o1,T o2) | 对象不需要实现这个接口,由单独的比较器去实现,与对象解耦合 |
Comparable | int compareTo(T o) | 对象需要实现这个接口,来装配可比性,使得对象自身具备比较功能 |