博客
关于我
阿里面试官崩溃,一个小小的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/

    你可能感兴趣的文章
    node模块化
    查看>>
    node环境下使用import引入外部文件出错
    查看>>
    node编译程序内存溢出
    查看>>
    Node读取并输出txt文件内容
    查看>>
    node防xss攻击插件
    查看>>
    noi 1996 登山
    查看>>
    noi 7827 质数的和与积
    查看>>
    NOI2010 海拔(平面图最大流)
    查看>>
    NOIp2005 过河
    查看>>
    NOIP2011T1 数字反转
    查看>>
    NOIP2014 提高组 Day2——寻找道路
    查看>>
    NOIp模拟赛二十九
    查看>>
    Nokia5233手机和我装的几个symbian V5手机软件
    查看>>
    Non-final field ‘code‘ in enum StateEnum‘
    查看>>
    none 和 host 网络的适用场景 - 每天5分钟玩转 Docker 容器技术(31)
    查看>>
    None还可以是函数定义可选参数的一个默认值,设置成默认值时实参在调用该函数时可以不输入与None绑定的元素...
    查看>>
    NOPI读取Excel
    查看>>
    NoSQL&MongoDB
    查看>>
    NoSQL介绍
    查看>>
    Notadd —— 基于 nest.js 的微服务开发框架
    查看>>