整理好了!2024年最常见 100 道 Java基础面试题(四十)

上一篇地址: 整理好了!2024年最常见 100 道 Java基础面试题(三十九)-CSDN博客

七十九、hashCode 和 identityHashCode 的区别?

在Java中,hashCode()identityHashCode() 是两种不同的方法,它们用于生成对象的散列码(hash code),但它们的用途和生成散列码的方式有所不同。

hashCode()

  1. 定义hashCode() 是 java.lang.Object 的一个方法,所有Java对象都继承了这个方法。
  2. 目的hashCode() 用于生成对象的散列码,通常用于散列表(如 HashMapHashSet 等)中确定对象的存储位置。
  3. 实现:默认的 hashCode() 实现可能会根据对象的内存地址、对象的属性值或其他因素来生成散列码。
  4. 重写:在重写 equals() 方法时,通常也需要重写 hashCode() 方法,以保证等价的对象有相同的散列码。
  5. 不变性:一个对象的 hashCode() 在 Java 应用程序执行期间通常保持不变。

identityHashCode()

  1. 定义identityHashCode() 是 java.util.Objects 类的一个静态方法。
  2. 目的identityHashCode() 用于生成对象的散列码,主要基于对象的身份(即内存地址)。
  3. 实现:它通常使用对象的内存地址来生成散列码,这意味着只要对象在内存中的位置不改变,它的 identityHashCode() 就保持不变。
  4. 使用场景identityHashCode() 通常用于性能敏感的场合,特别是在需要快速生成散列码时。它不依赖于对象的属性,因此不会因为对象状态的改变而改变。
  5. 不变性:一个对象的 identityHashCode() 在对象的生命周期内保持不变,即使对象被序列化和反序列化。

区别

  • 基础hashCode() 是对象本身的一个方法,而 identityHashCode() 是 Objects 类的一个静态方法。
  • 散列码生成hashCode() 可能基于对象的属性或其他逻辑生成散列码,而 identityHashCode() 主要基于对象的内存地址。
  • 重写hashCode() 可以被重写,并且当重写 equals() 方法时应该重写;identityHashCode() 不能被重写,因为它是基于对象的身份。
  • 稳定性identityHashCode() 在对象的整个生命周期内保持不变,而 hashCode() 的实现可能因对象状态的改变而改变。

示例

Object obj = new Object();
int hashCode = obj.hashCode(); // 使用hashCode()
int identityHashCode = Objects.identityHashCode(obj); // 使用identityHashCode()

注意事项

  • identityHashCode() 通常用于识别对象的身份,而不是比较对象的内容。
  • 在性能敏感的场合,如果不需要考虑对象内容的变化,identityHashCode() 可以提供更快的散列码生成。

总结

hashCode()identityHashCode() 都是用于生成对象散列码的方法,但它们的目的和实现方式不同。hashCode() 更多地用于基于对象内容的散列,而 identityHashCode() 则基于对象的身份。在选择使用哪种方法时,需要根据具体的应用场景和需求来决定。

八十、什么是 hash 冲突?

在计算机科学中,哈希冲突(Hash Collision)是指在使用哈希(Hash)函数将数据映射到哈希表(Hash Table)时,不同的输入数据经过哈希函数计算后得到了相同的哈希值(即哈希码)。由于哈希表的大小是有限的,而哈希函数可能将无限多的输入映射到有限的哈希表位置上,因此哈希冲突在哈希表的使用中是不可避免的。

哈希冲突的原因

  1. 有限的哈希表大小:哈希表的大小是有限的,而哈希函数可以处理的输入数据是无限的,这导致不同的输入数据可能映射到同一个哈希表位置。

  2. 哈希函数的局限性:尽管理想情况下哈希函数应该均匀分布输入数据,但实际上哈希函数可能无法完全避免冲突,特别是当输入数据具有某些特定模式时。

哈希冲突的解决策略

  1. 链地址法(Chaining)

    • 在哈希表的每个位置维护一个链表,所有映射到该位置的元素都存储在这个链表中。
  2. 开放寻址法(Open Addressing)

    • 当发生冲突时,寻找哈希表中的下一个空闲位置来存储数据。
  3. 双重哈希(Double Hashing)

    • 使用两个哈希函数,当第一个哈希函数发生冲突时,使用第二个哈希函数计算下一个可能的位置。
  4. 线性探测(Linear Probing)

    • 当发生冲突时,线性地探测表中的下一个空闲位置。
  5. 二次哈希(Quadratic Probing)

    • 类似于线性探测,但探测的步长是二次方增长的。

示例

假设我们有一个哈希表和以下哈希函数:

int hashFunction(String key) {
    int hash = 0;
    for (char c : key.toCharArray()) {
        hash = 31 * hash + c;
    }
    return hash % tableSize;
}

如果两个不同的字符串 "hello" 和 "hey" 经过哈希函数计算后都映射到了哈希表的第5个位置,那么这里就发生了哈希冲突。

注意事项

  • 哈希冲突是不可避免的,但可以通过选择合适的哈希函数和解决策略来最小化冲突的影响。
  • 哈希表的性能很大程度上取决于哈希函数的质量和冲突解决策略的有效性。

总结

哈希冲突是哈希表中的一个重要概念,它影响着哈希表的性能和效率。理解哈希冲突的原因和解决策略对于设计和使用高效的哈希表至关重要。通过合理的哈希函数设计和冲突解决机制,可以最大限度地减少冲突,提高哈希表的查找、插入和删除操作的性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/611141.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

rider自定义代码片段(以C#为例)

1.先看效果 2.在哪设置 File→Settings→Editor→Live Templates→C#3.咋定义 代码片段中的变量用$$包围,而且我们可以自定义变量名称,如CName。选择我们自定义的变量名称我们可以修改变量是否可以被修改以及变量将自动匹配的值。 比如将CName自动填充…

123. SQL优化技巧汇总

文章目录 1 避免使用select *2 用union all代替union3 小表驱动大表4 批量操作5 多用limit6 in中值太多7 增量查询8 高效的分页9 用连接查询代替子查询10 join的表不宜过多11 join时要注意12 控制索引的数量13 选择合理的字段类型14 提升group by的效率15 索引优化 sql优化是一…

07_Flutter使用NestedScrollView+TabBarView滚动位置共享问题修复

07_Flutter使用NestedScrollViewTabBarView滚动位置共享问题修复 一.案发现场 可以看到,上图中三个列表的滑动位置共享了,滑动其中一个列表,会影响到另外两个,这显然不符合要求,先来看下布局,再说明产生这个…

Nginx rewrite项目练习

Nginx rewrite练习 1、访问ip/xcz,返回400状态码,要求用rewrite匹配/xcz a、访问/xcz返回400 b、访问/hello时正常访问xcz.html页面server {listen 192.168.99.137:80;server_name 192.168.99.137;charset utf-8;root /var/www/html;location / {root …

TDN: Temporal Difference Networks for Efficient Action Recognition 论文阅读

TDN: Temporal Difference Networks for Efficient Action Recognition 论文阅读 Abstract1. Introduction2. Related work3. Temporal Difference Networks3.1. Overview3.2. Short-term TDM3.3. Long-term TDM3.4. Exemplar: TDN-ResNet 4. ExperimentsAblation studiesCompa…

智能创作时代:AI引领下的内容生产革命与效率提升

✨✨ 欢迎大家来访Srlua的博文(づ ̄3 ̄)づ╭❤~✨✨ 🌟🌟 欢迎各位亲爱的读者,感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢,在这里我会分享我的知识和经验。&am…

部署xwiki服务需要配置 hibernate.cfg.xml如何配置?

1. 定位 hibernate.cfg.xml 文件 首先,确保您可以在 Tomcat 的 XWiki 部署目录中找到 hibernate.cfg.xml 文件: cd /opt/tomcat/latest/webapps/xwiki/WEB-INF ls -l hibernate.cfg.xml如果文件存在,您可以继续编辑它。如果不存在&#xff…

梅兰日兰NSJ400N断路器NSJ400N可议价

梅兰日兰 NSJ400N 3 极 400 安培 600 伏交流电 紧凑型断路器 制造商的原始标签 脱扣单元:LS 功能 –(长时间和短时间) 负载侧凸耳 中断额定值:65kA 240 Vac 35kA 480 伏交流电压 18kA 600 伏交流电压 (外观可能与照…

中国地面基本气象逐小时数据获取方式

环境气象数据服务平台提供了全国大约2100个点位,2023年1月1日至今的小时级数据。包括气温、气压、湿度、风、降水等要素。 数据基于ECMWF ERA5-Land Hourly陆面再分析资料和中国地面基本气象观测逐三小时数据,使用机器学习模型加工所得,对比…

【17-Ⅱ】Head First Java 学习笔记

HeadFirst Java 本人有C语言基础,通过阅读Java廖雪峰网站,简单速成了java,但对其中一些入门概念有所疏漏,阅读本书以弥补。 第一章 Java入门 第二章 面向对象 第三章 变量 第四章 方法操作实例变量 第五章 程序实战 第六章 Java…

一文彻底读懂信息安全等级保护:包含等保标准、等保概念、等保对象、等保流程及等保方案(附:等保相关标准文档)

1. 什么是等级保护? 1.1. 概念 信息安全等级保护是指根据我国《信息安全等级保护管理办法》的规定,对各类信息系统按照其重要程度和保密需求进行分级,并制定相应的技术和管理措施,确保信息系统的安全性、完整性、可用性。根据等…

[C++][数据结构]哈希2:开散列/哈希桶的介绍和简单实现

前言 接着上一篇文章,我们知道了闭散列的弊端是空间利用率比较低,希望今天学习的开散列可以帮我们解决这个问题 引入 开散列法又叫链地址法(开链法),首先对关键码集合用散列函数计算散列地址**,具有相同地址的关键码归于同一子…

数据库表自增主键超过代码Integer长度问题

数据库自增主键是 int(10) unsigned类型的字段,int(M) 中 M指示最大显示宽度,不代表存储长度,实际int(1)也是可以存储21.47亿长度的数字,如果是无符号类型的,那么可以从0~42.94亿。 我们的表主键自增到21.47亿后&#…

英语学习笔记3——Sorry, sir.

Sorry, sir. 对不起,先生。 词汇 Vocabulary umbrella n. 伞,保护伞 注意读音 [ʌm’brelə] 英国人离不开雨伞。 please 请 特殊用法:让路(升调)      用餐礼仪(平调)      求求你…

大数据信用和征信报告的区别和联系,一定不要搞混了!

在当今数据驱动的社会,大数据的应用已经深入到各个领域。其中,大数据信用和征信报告成为金融、经济等领域中两个重要的概念。那么,大数据信用和征信报告有什么区别和联系呢? 一、定义与区别 1、大数据信用 大数据信用是指利用大数据技术&…

鸿蒙OpenHarmony技术:【Docker编译环境】

Docker环境介绍 OpenHarmony为开发者提供了两种Docker环境,以帮助开发者快速完成复杂的开发环境准备工作。两种Docker环境及适用场景如下: 独立Docker环境:适用于直接基于Ubuntu、Windows操作系统平台进行版本编译的场景。基于HPM的Docker环…

数学:人工智能领域的基石与灵魂

在科技日新月异的今天,人工智能(AI)已经渗透到了我们生活的方方面面,从智能家居、智能医疗到自动驾驶、智能客服,AI无处不在。然而,当我们赞叹于AI的神奇时,却往往忽视了其背后的推动力——数学…

2024.5.10

TCP服务器端 #include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);//设置窗口大小和窗口大小固定this->resize(727,879);this->setFixedSize(727,879);//创建…

泰尔指数和泰尔指数模型:代码、案例及复现

泰尔指数模型是衡量个人或地区收入差距的重要工具。参考朱红根(2023年)老师的方法,《农业经济问题》使用泰尔指数分析了中国不同地区数字乡村发展水平的差异。该资料包括了Stata全流程代码、案例数据、参考文献,并提供了Excel计算…

解决mybatis的配置文件没代码提示的问题

1.将org.apache.ibatis.builder.xml包里的两个dtd文件复制出来,jar包里复制 2.复制dtd的url地址: http://mybatis.org/dtd/mybatis-3-mapper.dtd 一样的做法! 3.关闭两个配置文件,重新打开,就可以有代码提示了&…
最新文章