Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
醒狮指南
JavaGuide
提交
8a4b4df0
J
JavaGuide
项目概览
醒狮指南
/
JavaGuide
与 Fork 源项目一致
从无法访问的项目Fork
通知
5
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
JavaGuide
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
8a4b4df0
编写于
5月 25, 2020
作者:
S
shuang.kou
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Update 应届生面试最爱问的几道Java基础问题.md
上级
795a0127
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
17 addition
and
32 deletion
+17
-32
docs/essential-content-for-interview/PreparingForInterview/应届生面试最爱问的几道Java基础问题.md
...or-interview/PreparingForInterview/应届生面试最爱问的几道Java基础问题.md
+17
-32
未找到文件。
docs/essential-content-for-interview/PreparingForInterview/应届生面试最爱问的几道Java基础问题.md
浏览文件 @
8a4b4df0
...
...
@@ -223,57 +223,42 @@ public class test1 {
-
String 中的 equals 方法是被重写过的,因为 object 的 equals 方法是比较的对象的内存地址,而 String 的 equals 方法比较的是对象的值。
-
当创建 String 类型的对象时,虚拟机会在常量池中查找有没有已经存在的值和要创建的值相同的对象,如果有就把它赋给当前引用。如果没有就在常量池中重新创建一个 String 对象。
## 三 hashCode
与 equals
(重要)
## 三 hashCode
() 与 equals()
(重要)
面试官可能会问你:“你重写过
hashcode 和 equals 么,为什么重写 equals 时必须重写 hashCode
方法?”
面试官可能会问你:“你重写过
`hashcode`
和
`equals `
么,为什么重写
`equals`
时必须重写
`hashCode`
方法?”
### 3.1 hashCode
()
介绍
### 3.1 hashCode
()
介绍
hashCode() 的作用是获取哈希码,也称为散列码;它实际上是返回一个 int 整数。这个哈希码的作用是确定该对象在哈希表中的索引位置。hashCode() 定义在 JDK 的 Object.java 中,这就意味着 Java 中的任何类都包含有 hashCode() 函数。另外需要注意的是: Object
的 hashcode 方法是本地方法,也就是用 c 语言或 c++ 实现的,该方法通常用来将对象的 内存地址 转换为整数之后返回。
`hashCode()`
的作用是获取哈希码,也称为散列码;它实际上是返回一个 int 整数。这个哈希码的作用是确定该对象在哈希表中的索引位置。
`hashCode() `
定义在 JDK 的
`Object`
类中,这就意味着 Java 中的任何类都包含有
`hashCode()`
函数。另外需要注意的是:
`Object`
的 hashcode 方法是本地方法,也就是用 c 语言或 c++ 实现的,该方法通常用来将对象的 内存地址 转换为整数之后返回。
```
java
/**
* Returns a hash code value for the object. This method is
* supported for the benefit of hash tables such as those provided by
* {@link java.util.HashMap}.
* <p>
* As much as is reasonably practical, the hashCode method defined by
* class {@code Object} does return distinct integers for distinct
* objects. (This is typically implemented by converting the internal
* address of the object into an integer, but this implementation
* technique is not required by the
* Java™ programming language.)
*
* @return a hash code value for this object.
* @see java.lang.Object#equals(java.lang.Object)
* @see java.lang.System#identityHashCode
*/
public
native
int
hashCode
();
public
native
int
hashCode
();
```
散列表存储的是键值对(key-value),它的特点是:能根据“键”快速的检索出对应的“值”。这其中就利用到了散列码!(可以快速找到所需要的对象)
### 3.2 为什么要有 hashCode
### 3.2 为什么要有 hashCode
?
**我们以“
HashSet
如何检查重复”为例子来说明为什么要有 hashCode:**
**我们以“
`HashSet`
如何检查重复”为例子来说明为什么要有 hashCode:**
当你把对象加入
HashSet 时,HashSet 会先计算对象的 hashcode 值来判断对象加入的位置,同时也会与其他已经加入的对象的 hashcode 值作比较,如果没有相符的 hashcode,HashSet 会假设对象没有重复出现。但是如果发现有相同 hashcode 值的对象,这时会调用 equals()方法来检查 hashcode 相等的对象是否真的相同。如果两者相同,HashSet
就不会让其加入操作成功。如果不同的话,就会重新散列到其他位置。(摘自我的 Java 启蒙书《Head fist java》第二版)。这样我们就大大减少了 equals 的次数,相应就大大提高了执行速度。
当你把对象加入
`HashSet`
时,
`HashSet`
会先计算对象的 hashcode 值来判断对象加入的位置,同时也会与其他已经加入的对象的 hashcode 值作比较,如果没有相符的 hashcode,
`HashSet`
会假设对象没有重复出现。但是如果发现有相同 hashcode 值的对象,这时会调用 equals()方法来检查 hashcode 相等的对象是否真的相同。如果两者相同,
`HashSet`
就不会让其加入操作成功。如果不同的话,就会重新散列到其他位置。(摘自我的 Java 启蒙书《Head fist java》第二版)。这样我们就大大减少了 equals 的次数,相应就大大提高了执行速度。
### 3.3
hashCode()与 equals()的相关规定
### 3.3
为什么重写 `equals` 时必须重写 `hashCode` 方法?
1.
如果两个对象相等,则 hashcode 一定也是相同的
2.
两个对象相等,对两个对象分别调用 equals 方法都返回 true
3.
两个对象有相同的 hashcode 值,它们也不一定是相等的
4.
**因此,equals 方法被覆盖过,则 hashCode 方法也必须被覆盖**
5.
hashCode()的默认行为是对堆上的对象产生独特值。如果没有重写 hashCode(),则该 class 的两个对象无论如何都不会相等(即使这两个对象指向相同的数据)
如果两个对象相等,则 hashcode 一定也是相同的。两个对象相等,对两个对象分别调用 equals 方法都返回 true。但是,两个对象有相同的 hashcode 值,它们也不一定是相等的 。
**因此,equals 方法被覆盖过,则 `hashCode` 方法也必须被覆盖。**
> `hashCode()`的默认行为是对堆上的对象产生独特值。如果没有重写 `hashCode()`,则该 class 的两个对象无论如何都不会相等(即使这两个对象指向相同的数据)
### 3.4 为什么两个对象有相同的 hashcode 值,它们也不一定是相等的?
在这里解释一位小伙伴的问题。以下内容摘自《Head Fisrt Java》。
因为 hashCode() 所使用的杂凑算法也许刚好会让多个对象传回相同的杂凑值。越糟糕的杂凑算法越容易碰撞,但这也与数据值域分布的特性有关(所谓碰撞也就是指的是不同的对象得到相同的 hashCode)。
因为
`hashCode()`
所使用的杂凑算法也许刚好会让多个对象传回相同的杂凑值。越糟糕的杂凑算法越容易碰撞,但这也与数据值域分布的特性有关(所谓碰撞也就是指的是不同的对象得到相同的
`hashCode`
。
我们刚刚也提到了
`HashSet`
,如果
`HashSet`
在对比的时候,同样的 hashcode 有多个对象,它会使用
`equals()`
来判断是否真的相同。也就是说
`hashcode`
只是用来缩小查找成本。
我们刚刚也提到了 HashSet,如果 HashSet 在对比的时候,同样的 hashcode 有多个对象,它会使用 equals() 来判断是否真的相同。也就是说 hashcode 只是用来缩小查找成本。
更多关于
`hashcode()`
和
`equals()`
的内容可以查看:
[
Java hashCode() 和 equals()的若干问题解答
](
https://www.cnblogs.com/skywang12345/p/3324958.html
)
## 四 String 和 StringBuffer、StringBuilder 的区别是什么?String 为什么是不可变的?
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录