【大白话说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
相关推荐
小bo波6 分钟前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking41 分钟前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
Asize1 小时前
多模态生图:从 Vite 工程化到前端调用 Qwen Image
javascript·人工智能·后端
java小白小1 小时前
SpringBoot(09):缓存实战——穿透、雪崩、击穿的解决方案
后端
java小白小1 小时前
SpringBoot(08):Redis 集成——5 分钟给你的项目加上缓存
后端
LiuMingXin1 小时前
意图与代码之间:AI编程范式全景解读
前端·后端·面试
用户34232323763172 小时前
边缘计算与云边协同——当采集不再只是“上传“
后端
壹方秘境2 小时前
ApiCatcher支持抓包HTTP传输大文件的实现原理分享
前端·后端·客户端
神奇小汤圆2 小时前
2026最新·最全·最实用|Java岗面试真题(已收录GitHub)
后端
神奇小汤圆3 小时前
面试官当场让我手写Java线程安全工具类,我写完直接拿到了35K offer
后端