Skip to content

Commit c554ff7

Browse files
committedFeb 18, 2022
update java-basic-questions-01.md
1 parent 55733ca commit c554ff7

File tree

1 file changed

+2
-2
lines changed

1 file changed

+2
-2
lines changed
 

‎docs/java/basis/java-basic-questions-01.md

+2-2
Original file line numberDiff line numberDiff line change
@@ -584,7 +584,7 @@ public native int hashCode();
584584
585585
下面这段内容摘自我的 Java 启蒙书《Head First Java:
586586
587-
> 当你把对象加入 `HashSet` 时,`HashSet` 会先计算对象的 `hashCode` 值来判断对象加入的位置,同时也会与其他已经加入的对象的 `hashCode` 值作比较,如果没有相符的 `hashCode`,`HashSet` 会假设对象没有重复出现。但是如果发现有相同 `hashCode` 值的对象,这时会调用 `equals()` 方法来检查 `hashCode` 相等的对象是否真的相同。如果两者相同,`HashSet` 就不会让其加入操作成功。如果不同的话,就会重新散列到其他位置。这样我们就大大减少了 `equals` 的次数,相应就大大提高了执行速度。
587+
> 当你把对象加入 `HashSet` 时,`HashSet` 会先计算对象的 `hashCode` 值来判断对象加入的位置,同时也会与其他已经加入的对象的 `hashCode` 值作比较,如果没有相符的 `hashCode`,`HashSet` 会假设对象没有重复出现。但是如果发现有相同 `hashCode` 值的对象,这时会调用 `equals()` 方法来检查 `hashCode` 相等的对象是否真的相同。如果两者相同,`HashSet` 就不会让其加入操作成功。如果不同的话,就会重新散列到其他位置。这样我们就大大减少了 `equals` 的次数,相应就大大提高了执行速度。
588588
589589
其实, `hashCode()` 和 `equals()`都是用于比较两个对象是否相等。
590590
@@ -605,7 +605,7 @@ public native int hashCode();
605605
总结下来就是 :
606606
607607
- 如果两个对象的`hashCode` 值相等,那这两个对象不一定相等(哈希碰撞)。
608-
- 如果两个对象的`hashCode` 值相等并且`equals()`方法返回 `true`,我们才认为这两个对象相等。
608+
- 如果两个对象的`hashCode` 值相等并且`equals()`方法也返回 `true`,我们才认为这两个对象相等。
609609
- 如果两个对象的`hashCode` 值不相等,我们就可以直接认为这两个对象不相等。
610610
611611
相信大家看了我前面对 `hashCode()` 和 `equals()` 的介绍之后,下面这个问题已经难不倒你们了。

0 commit comments

Comments
 (0)
Please sign in to comment.