【大白话说Java面试题】【Java基础篇】第7题:HashMap的get流程是什么

第7题:HashMap的get流程是什么

📚 回答:

  • 步骤1:判断集合是否为空

    调用HashMapget方法时,首先会根据key计算哈希值。如果集合为空(即数组尚未初始化),直接返回null

  • 步骤2:计算位置下标

    如果集合不为空,将key的哈希值与数组长度减1(length - 1)进行按位与运算,得到目标元素的位置下标。

  • 步骤3:查找目标元素

    • 情况1:目标位置为空
      如果该位置没有元素,直接返回null
    • 情况2:目标位置有元素
      判断该位置元素的hash值和key是否与要查找的元素一致。如果一致,说明找到了目标元素,直接返回。
      • 如果不一致,则继续向下查找:
        • 如果下一个节点为空,直接返回null
        • 如果下一个节点不为空:
          • 如果是红黑树节点(TreeNode),走红黑树的查找逻辑。
          • 如果是普通链表节点,走链表遍历逻辑,逐一比较每个节点的hash值和key,直到找到目标元素或遍历结束。
    java 复制代码
    // 源码位置:java.util.HashMap#getNode
    /**
     * Implements Map.get and related methods.
     *
     * @param hash hash for key
     * @param key the key
     * @return the node, or null if none
     */
    final Node<K,V> getNode(int hash, Object key) {
        Node<K,V>[] tab; Node<K,V> first, e; int n; K k;
        if ((tab = table) != null && (n = tab.length) > 0 &&
            (first = tab[(n - 1) & hash]) != null) {
            if (first.hash == hash && // always check first node
                ((k = first.key) == key || (key != null && key.equals(k))))
                return first;
            if ((e = first.next) != null) {
                if (first instanceof TreeNode)
                    return ((TreeNode<K,V>)first).getTreeNode(hash, key);
                do {
                    if (e.hash == hash &&
                        ((k = e.key) == key || (key != null && key.equals(k))))
                        return e;
                } while ((e = e.next) != null);
            }
        }
        return null;
    }

💡 面试官视角

  • 面试官可能会问"为什么链表和红黑树的查找逻辑不同?"
    答:因为红黑树的时间复杂度为O(log n),比链表的**O(n)**更高效,所以在冲突较多时使用红黑树能显著提升性能。
  • 面试官可能会追问"如果找不到目标元素会返回什么?"
    答:如果没有找到对应的key,最终会返回null
相关推荐
石山代码16 小时前
ArrayList / HashMap / ConcurrentHashMap
java·开发语言
笑尘~Y17 小时前
每日技术面试高频题精选
面试
拼尽全力前进17 小时前
Guava Cache vs Caffeine 面试详解
面试·职场和发展·guava
AskHarries17 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
Moment18 小时前
长上下文会最终杀死 Rag 吗?
前端·javascript·后端
daidaidaiyu18 小时前
ThingsBoard 规则链系统源码分析和自定义定时器
java
蝎子莱莱爱打怪19 小时前
🚀 🚀🚀2026年5月GitHub月榜精选:17个项目中挑出10个推荐,实操4个!
人工智能·后端·ai编程
小毛驴85019 小时前
spring-boot-maven-plugin,maven-compiler-plugin 功能对比
java·python·maven
csdn_aspnet19 小时前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
霸道流氓气质19 小时前
通义灵码 IDEA 插件完全使用指南
java·ide·intellij-idea