类实现了Comparable接口就表明类的实例本身具有内在的排序关系(natural ordering)。
因此,该类可以与很多泛型算法和集合实现进行协作。
而我们之需要实现Comparable接口唯一的方法——compareTo。
以下是相关规则:
第四条并不是必须的,但值得了解一下。
一些有序结构中的等同性比较可能会使用compareTo而非equals。
鉴于这种情况,我们需要把compareTo和equals兼容起来。
但特殊情况不必这样,比如BigDecimal类中new BigDecimal("1.00")和new BigDecimal("1.0"),两者equals结果为false,compareTo结果为0。
对于类中不同类型的field进行不同的比较方法:
通常情况下,对于一个类的关键field,我们可以根据它们的关键程度做一个优先级。
从最关键的开始逐个比较,得出非零结果时立即返回。
下面是例子:
上面的例子中的field都是非浮点基本类型,于是作者对其进行优化。
鉴于compareTo只需要返回值的符号而非大小,因此用差值代替逻辑比较符。
但是这种用法需要注意,该field的类型可能无法容纳两个数值的差值。
比如Integer.MAX_VALUE-(-1)或者Integer.MIN_VALUE-1之类的。
如果可以保证field值不会是负值,则不会出现这种情况。