中有一些代码java.util.HashMap.TreeNode#putTreeVal(),如下所示:
if ((ph = p.hash) > h)
dir = -1;
else if (ph < h)
dir = 1;
else if ((pk = p.key) == k || (k != null && k.equals(pk)))
return p;
else if ((kc == null &&
(kc = comparableClassFor(k)) == null) ||
(dir = compareComparables(kc, k, pk)) == 0) {
if (!searched) {
TreeNode<K,V> q, ch;
searched = true;
if (((ch = p.left) != null &&
(q = ch.find(h, k, kc)) != null) ||
((ch = p.right) != null &&
(q = ch.find(h, k, kc)) != null))
return q;
}
dir = tieBreakOrder(k, pk);
}
有两种情况:h小于ph、h大于ph。通常,代码的(pk = p.key) == k || (k != null && k.equals(pk))意思是h等于ph,但我不知道为什么在那之后还有其他的。
当两个对象hashCode彼此相等但又会为假时==,这是什么情况?euqlas()
Object的类覆盖equals()方法什么时候会导致这种情况呢?但是我曾经听说过覆盖也equals()必须覆盖hashCode(),所以这个问题不会发生。
我希望有人能告诉我哪种情况会导致第三次else if。
当年话下
倚天杖
相关分类