Java中Comparable和Comparator区别小结

转载自
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) 对象需要实现这个接口,来装配可比性,使得对象自身具备比较功能

你可能感兴趣的:(JAVA,JDK)