Java 中 Comparable 和 Comparator 比较
Comparable 是一个排序接口
一个类实现了Comparable接口 就意味着这个类支持排序。 那么这个类组成的LIst 就可以就可以直接调用 Collections.sort(LIst list) 方法了。 Collections(该类包含了对集合类操作和返回的静态方法)。
Comparetor 是一个比较器接口。
我们如果需要控制某个类的次序,可以建立一个类的比较器来进行比较。 但是你也可以在这个类上直接实现 Comparator 接口 ,但是你真正调用的时候 比较器 和 类名 相同 你不觉得别扭吗 反正我是觉得别扭。最好也别这么用。
Comparable 和 Comparator 比较
都是实现接口 实现的时候都需要重写差不多的比较函数 主要的区别还是在于函数调用的
我们不难发现:Comparable 相当于“内部比较器” , 而Comparetor 更像外部比较器 。
实现 Comparable 的类的List 可以直接调用 Collections.sort 函数 .
正常 List 在调用 Collections.sort 函数的时候 需要再传一个是实现了Comparator 的比较器(当然在这也可以用匿名内部类了) 或者 直接调用 LIst.sort(Comparator <? super E> c) 方法.但是前者就不可以调用了。
功能大同小异 看你的使用的习惯了。