Bad practice - Class defines compareTo(...) and uses Object.equals()(不好的做法 - 类定义 compareTo(...) 并使用 Object.equals())
问题描述
想知道列出的方法需要做什么
Wondering what needs to be done for listed method
public final int compareTo(final FieldDTO o) {
return o.available.compareTo(this.available);
它在第 2 行抛出异常说明不好的做法 - 类定义 compareTo(...) 并使用 Object.equals() 16 天
field 定义 compareTo(FieldDTO) 并使用 Object.equals()
its throwing exception on line 2 stating
Bad practice - Class defines compareTo(...) and uses Object.equals() 16 days
field defines compareTo(FieldDTO) and uses Object.equals()
不知道我应该如何处理.提前致谢.
Not sure how should i handle this. Thanks in advance.
推荐答案
如果你定义 compareTo
你至少应该定义 equals
If you define compareTo
you should at least define equals
boolean equals(it) {
return compareTo(it) == 0;
}
否则当你把你的对象放在 Map
s 和 Set
s 时你会遇到奇怪的问题.通常也定义 hashCode
是一种好习惯.
otherwise you will get strange problems when you put your object in Map
s and Set
s. It is generally good practice to also define hashCode
.
这篇关于不好的做法 - 类定义 compareTo(...) 并使用 Object.equals()的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:不好的做法 - 类定义 compareTo(...) 并使用 Object.equals()


基础教程推荐
- 如何在 JFrame 中覆盖 windowsClosing 事件 2022-01-01
- 多个组件的复杂布局 2022-01-01
- 不推荐使用 Api 注释的描述 2022-01-01
- 大摇大摆的枚举 2022-01-01
- 从 python 访问 JVM 2022-01-01
- Java 实例变量在两个语句中声明和初始化 2022-01-01
- Java Swing计时器未清除 2022-01-01
- 在 Java 中创建日期的正确方法是什么? 2022-01-01
- 验证是否调用了所有 getter 方法 2022-01-01
- 如何在 Spring @Value 注解中正确指定默认值? 2022-01-01