java – compareTo方法的哪个用法更容易理解?
发布时间:2020-12-15 08:34:06 所属栏目:Java 来源:网络整理
导读:我想基于布尔值对对象进行排序,我想在假值之前对真值进行排序. compareTo的哪些实现更具可读性? 使用-1更改默认行为 public class Example implements ComparableExample{ Boolean isOk; public int compareTo(Example o) { return -1 * this.isOk.compareT
我想基于布尔值对对象进行排序,我想在假值之前对真值进行排序.
compareTo的哪些实现更具可读性? 使用-1更改默认行为 public class Example implements Comparable<Example>{ Boolean isOk; public int compareTo(Example o) { return -1 * this.isOk.compareTo(o.isOk); } } 或者交换Boolean#compareTo方法的两边? public class ExampleTwo implements Comparable<ExampleTwo>{ Boolean isOk; public int compareTo(ExampleTwo o) { return o.isOk.compareTo(this.isOk); } } 解决方法
第一种形式是错误的 – 因为如果compareTo返回Integer.MIN_VALUE,它将尝试否定它 – 并再次导致Integer.MIN_VALUE.
解决这个问题的最简单方法就是使用第二个代码段中的代码. 另一方面: >如果isOk为null,则两者都可能失败>如果你真的只使用布尔值,一个简单的真值表可能更简单> Boolean.compareTo可能永远不会返回Integer.MIN_VALUE.我不会依赖它. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |