博客
关于我
阿里面试官崩溃,一个小小的HashMap扯半个小时
阅读量:185 次
发布时间:2019-02-28

本文共 1165 字,大约阅读时间需要 3 分钟。

HashMap的核心原理与面试经历

HashMap的内部结构与插入原理

HashMap作为Java中最常用的非线程安全的集合,其内部结构和插入原理是面试中常见的重点话题。HashMap的核心思想是通过数组和链表或红黑树的结合,实现高效的数据存取操作。具体来说,HashMap采用数组存储键值对的位置索引,而通过哈希函数计算键的位置。哈希函数的设计非常关键,既要降低碰撞概率,又要保证插入和查找操作的高效性。

HashMap的哈希函数与碰撞解决方案

HashMap的哈希函数设计分为两部分:首先,计算键的哈希值,然后将其与数组长度-1进行按位与操作,从而得到实际存储位置。这种操作比传统的取模运算更高效,避免了溢出问题。为了进一步降低碰撞概率,HashMap引入了扰动函数。扰动函数通过将哈希值的高位与低位混合,减少碰撞的可能性。具体实现是对哈希值进行四次移位和异或操作,混合了高位和低位的信息。

!图片描述被移除

HashMap的优化变化

随着时间的推移,HashMap不断进行了优化。Java 1.8相比1.7在性能和安全性上有了显著提升:

  • 链表转换为红黑树的条件:在1.7中,链表长度达到8时会被转换为红黑树。而1.8将这个阈值降低为6,进一步优化了查找性能。
  • 插入方式优化:1.7使用头插法可能导致链表反转,影响多线程环境下的安全性。1.8改用尾插法,避免了链表反转问题。
  • 扩容逻辑优化:1.7在扩容时需要重新计算所有键的哈希值,1.8则通过简单的逻辑判断,直接定位原数组中的节点到新数组的位置,提升了扩容效率。
  • 线程安全问题与解决方案

    尽管HashMap本身是非线程安全的,但在多线程环境下仍然可能出现问题。解决方案包括:

  • 使用线性化的Map:如Hashtable,通过对方法进行同步锁定。
  • 使用包装类:如Collections.synchronizedMap,通过对象锁实现线程安全。
  • 使用并发包裹Map:如ConcurrentHashMap,采用分段锁策略,锁粒度更小,支持更高的并发度。
  • !图片描述被移除

    LinkedHashMap与TreeMap的实现

    除了默认的HashMap,Java还提供了其他类型的Map,如LinkedHashMapTreeMap,它们以不同的方式实现有序性:

    • LinkedHashMap:通过维护一个双向链表,记录插入或访问顺序,实现按访问顺序排列。
    • TreeMap:基于红黑树的结构,按照键的自然顺序或自定义比较器进行排序。

    !图片描述被移除

    最后

    面对HashMap的面试问题,重点突出其内部结构、哈希函数、优化变化以及线程安全等方面的知识。通过结合实际项目经验和代码理解,能够更深入地解答相关问题。如果对某些细节还有疑问,可以参考Java官方文档或相关技术博客,进一步加深理解。

    转载地址:http://blzc.baihongyu.com/

    你可能感兴趣的文章
    Oracle系列:安装Oracle RAC数据库(二)
    查看>>
    oracle系统 介绍,ORACLE数据库管理系统介绍
    查看>>
    oracle获取数据库表、字段、注释、约束等
    查看>>
    oracle表空间查询维护命令大全之三(暂时表空间)史上最全
    查看>>
    oracle表访问方式
    查看>>
    Oracle触发器
    查看>>
    Oracle计划将ZGC项目提交给OpenJDK
    查看>>
    oracle账号共享
    查看>>
    Oracle闪回技术(Flashback)
    查看>>
    oracle零碎要点---ip地址问题,服务问题,系统默认密码问题
    查看>>
    oracle零碎要点---oracle em的web访问地址忘了
    查看>>
    Oracle零碎要点---多表联合查询,收集数据库基本资料
    查看>>
    Oracle静默安装
    查看>>
    Oracle面试题:Oracle中truncate和delete的区别
    查看>>
    ThreadLocal线程内部存储类
    查看>>
    thinkphp 常用SQL执行语句总结
    查看>>
    Oracle:ORA-00911: 无效字符
    查看>>
    Text-to-Image with Diffusion models的巅峰之作:深入解读 DALL·E 2
    查看>>
    TCP基本入门-简单认识一下什么是TCP
    查看>>
    tableviewcell 中使用autolayout自适应高度
    查看>>