[英]Overriding equals method doesn't work
我在这里和其他网站上一直在浏览很多类似的问题。 我似乎无法解决这个问题。
我有一节课:
public class Event {
public String Item;
public String Title;
public String Desc;
@Override
public boolean equals(Object o) {
return true;
}
}
我试图在ArrayList<Event> events
使用此类,但我找不到使events.contains("item")
工作的方法。 我试过debuging,我发现它甚至没有进入被覆盖的方法。
我究竟做错了什么?
那是因为你打破了equals()
合约中指定的对称性:如果任何事件等于"item"
( 这是一个String ), "item"
也应该等于任何事件。
实际上,Java所做的是在列表中调用indexOf("item")
,并检查它是否为正数。
现在, indexOf()
在ArrayList
就像这样工作(参见这里的完整源代码 ):
for (int i = 0; i < size; i++)
if ("item".equals(elementData[i]))
return i;
所以基本上是这里调用的String的equals()方法,而不是你当然返回false的方法。
只需为函数指定一个Event
参数即可解决此问题,例如:
events.contains( new Event("item", "title", "desc") )
请注意,您必须为您的类创建一个正确的构造函数,以初始化成员。
您还应该覆盖public int hashCode()
。 这两种方法密切相关。
阅读更多相关信息: http : //www.javapractices.com/topic/TopicAction.do?Id=17
当您重写equals()
方法时,您还必须重写hashcode()
方法,因为它们齐头并进。 如果两个对象相等,则它们必须具有相同的哈希码。 Hashmaps使用它来评估保存位置。 如果两个对象不相等,它们可能具有相同的哈希码,也可能不具有相同的哈希码。
在这种情况下,您只需要覆盖equals方法,而不是hashCode方法。
当您想要将类的对象用作HashMap中的键时,应该重写hashCode和equals方法。 HashMap使用array + linkedList的结构。 添加键值对时,首先根据键的hashCode进行一些计算,得到数组中的索引; 然后遍历该索引位置的linkedList,以查找键值对是否已存在。 如果是,它将用新值覆盖记录; 否则将键值对添加到该linkedList的末尾。 找到密钥时,过程很熟悉。 因此,如果未覆盖hashCode方法,则将无法在数组中进行第一轮搜索。 这就是你需要覆盖这两种方法的原因。 这不是说某个地方说这两种方法之间存在契约,或者它们之间存在密切关系。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.