HashMap初步解析

HashMap集合:
    1、HashMap集合底层是哈希表/散列表的数据结构。
    
    
    2、哈希表是一个怎样的数据结构呢?
        哈希表是一个数组和单向链表的结合体。
        数组:在查询方面效率很高,随机增删方面效率很低。
        单向链表:在随机增删方面效率较高,在查询方面效率很低。
        哈希表将以上的两种数据结构融合在一起,充分发挥它们各自的优点。
        
        
    3、HashMap集合底层的源代码:
        public class HashMap{
            // HashMap底层实际上就是一个数组。(一维数组)
            Node<K,V>[] table;
            // 静态的内部类HashMap.Node
            static class Node<K,V> {
                final int hash; // 哈希值(哈希值是key的hashCode()方法的执行结果。hash值通过哈希函数/算法,可以转换存储成数组的下标。)
                final K key; // 存储到Map集合中的那个key
                V value; // 存储到Map集合中的那个value
                Node<K,V> next; // 下一个节点的内存地址。
            }
        }
        哈希表/散列表:一维数组,这个数组中每一个元素是一个单向链表。(数组和链表的结合体。)
        
        
    4、最主要掌握的是:
        map.put(k,v)
        v = map.get(k)
        以上这两个方法的实现原理,是必须掌握的。
        
        map.put(k,v)实现原理:
          1.将k,v封装到Node对象中
          2.底层调用k的hashCode()方法,得出hash值
          3.通过 哈希算法/哈希函数 将hash转化为数组下标,
          若该下标位置上没有元素,就把Node添加到该位置上
          若该下标位置上有链表,此时会拿着k与链表上的每一个节点的k进行equals比较:
            若比较结果都为false,则将新节点Node添加到链表末尾,
            若有一个节点的equals返回了true,则这个节点的value将被覆盖
            
        v=map.get(k)实现原理:
          1.先调用k的hashCode()方法,得出hash值
          2.通过 哈希算法/哈希函数 将hash转化为数组下标,通过数组下标快速定位到某个位置上,
          若该下标位置上没有元素,返回null
          若该下标位置上有链表,此时会拿着k与链表上的每一个节点的k进行equals比较:
            若比较结果都为false,则返回null
            若有一个节点的equals返回了true,则返回这个节点的value
        
        
    5、HashMap集合的key部分特点:
        无序,不可重复。
        为什么无序? 因为不一定挂到哪个单向链表上。
        不可重复是怎么保证的? equals方法来保证HashMap集合的key不可重复。
        如果key重复了,value会覆盖。

        放在HashMap集合key部分的元素其实就是放到HashSet集合中了。
        所以HashSet集合中的元素也需要同时重写hashCode()+equals()方法。
        

    6、哈希表HashMap使用不当时无法发挥性能!
        假设将所有的hashCode()方法返回值固定为某个值,那么会导致底层哈希表变成了
        纯单向链表。这种情况我们成为:散列分布不均匀。
        什么是散列分布均匀?
            假设有100个元素,10个单向链表,那么每个单向链表上有10个节点,这是最好的,
            是散列分布均匀的。
        假设将所有的hashCode()方法返回值都设定为不一样的值,可以吗,有什么问题?
            不行,因为这样的话导致底层哈希表就成为一维数组了,没有链表的概念了。
            也是散列分布不均匀。
        散列分布均匀需要你重写hashCode()方法时有一定的技巧。
        
        
    7、重点:放在HashMap集合key部分的元素,以及放在HashSet集合中的元素,需要同时重写hashCode和equals方法。
    
    
    8、HashMap集合的默认初始化容量是16,默认加载因子是0.75
        这个默认加载因子是当HashMap集合底层数组的容量达到75%的时候,数组开始扩容。

        重点,记住:HashMap集合初始化容量必须是2的倍数,这也是官方推荐的,
        这是因为达到散列均匀,为了提高HashMap集合的存取效率,所必须的。
        
    9、在jdk1.8之后,如果哈希表单向链表中元素超过8个,单向链表这种数据结构会变成红黑树数据结构。
    当红黑树上的节点数量小于6时,会重新把红黑树这种数据结构变成单向链表。
       这是为了提高检索效率,二叉树的检索会再次缩小扫描范围。提高效率。
    

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值