java HashMap 源码分析

本文详细探讨了Java HashMap的数据结构,确认其为数组加单向链表的形式。通过源码分析,解释了HashMap中hash存在的原因以及计算过程,包括高16位和低16位的异或运算以及与运算确保下标在数组范围内。同时,文章讨论了扰动函数在避免哈希冲突中的作用,并解释了为何JDK8中仅进行一次扰动的原因。最后,概述了HashMap的put流程及其背后的思考点。
摘要由CSDN通过智能技术生成

一、HashMap内部的数据结构是什么?

数组+单向链表
image.png

二、怎么验证内部结构是数组和单向链表?

a、数组:通过HashMap源码知道、HashMap内部有个属性 transient Node<K,V>[] table
b、单向链表:内部类Node里面维护了一个next的属性 Node<K,V> next,是指向下一个节点的;

三、HashMap里面为什么会有hash的存在?hash计算的理解?

我们先看下我的事例代码

public class HashMapDemo {

    public static void main(String[] args) {
        HashMap<String,String> map=new HashMap<String, String>();
        String keys="names";
        String values="zhangsans";
        map.put(keys,values);
        System.out.println("数组的默认大小:"+ (1<<4));
        System.out.println("对应二进制ÿ
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值