在我的Emp类中有两种方法
class Emp
{
String empId;
public boolean equals(Emp e){..}
public boolean equals(Object o){..}
public int hashCode(){
return empId.hashCode();
}
}现在,如果正试图将Emp对象添加到HashSet<Emp>中。
如果我看一下HashMap的putVal方法的代码,它用于比较和将值放到集合中。每次调用java.lang.Object.So版本时,代码都不会将传递的对象转换为equals(Emp)。
但是每次调用equals(Object o)时,我都想知道这个Emp何时转换为java.lang.Object,以便everyTime调用equals(Object o)。
下面是我使用的putval片段:
final V putVal(int hash, K key, V value, boolean onlyIfAbsent,
boolean evict) {
Node<K,V>[] tab; Node<K,V> p; int n, i;
if ((tab = table) == null || (n = tab.length) == 0)
n = (tab = resize()).length;
if ((p = tab[i = (n - 1) & hash]) == null)
tab[i] = newNode(hash, key, value, null);
else {
Node<K,V> e; K k;
if (p.hash == hash &&
((k = p.key) == key || (key != null && key.equals(k))))
e = p;
else if (p instanceof TreeNode)
e = ((TreeNode<K,V>)p).putTreeVal(this, tab, hash, key, value);
....
}发布于 2017-03-29 06:39:07
编译器删除泛型类型参数,因此在编译代码时,K和V成为Object。因此,key.equals(k)执行equals(Object o)。
发布于 2017-03-29 06:48:06
除了Eran的正确论点之外,重点是不要这样做。
不要超载 public boolean equals(Object)!
这是一个在Java中定义非常明确和已知的契约的方法。只添加您自己的公共equals(Emp) (只添加)会增加您创建bug的风险。
如果有的话,将该方法设置为私有;并在equals(Object)方法中调用它。
您知道,重载是一个应该非常小心使用的概念,因为所有这些都发生在编译时;特别是当将其与多态性相结合时,意外的事情可能会在运行时发生(正如您刚刚学到的)。
https://stackoverflow.com/questions/43086052
复制相似问题