Java数据结构-Hashmap

这篇博客详细探讨了Java中HashMap的数据结构,包括其内部的Entry数组和每个Entry的key、value、next和hash属性。解释了put和get方法的工作原理,强调了HashMap的无序性和在元素分布不均时可能影响性能的特点。
摘要由CSDN通过智能技术生成

内部结构图

这里写图片描述

实现原理

HashMap内部维护着一个Entry类型的数组,默认大小16:Entry<K,V>[] table,这个Entry对象包含key,value,next,hash四个属性,key和value即是你map.put(Key,Value)的key和value,hash是使用key经过算法得出的一个hash值,当我们通过get方法取值的时候即是比较的key的hash值。而next保存的是下一个Entey对象的引用,当调用put方法的时候,hashmap会根据key和数组大小决定这个key在数组中的位置,那么就有可能存在key不同但是算出来的位置相同的情况,这个时候就会把当前位置的值设置为新值的next元素,并把新值存放在当前元素值得位置。

特点

由于这种数据结构,hashmap是无序的。也正是由于这种结构,有可能会存在数组很大,但是实际元素量很少的情况,这种情况下取值是比较慢的。

常用方法源码

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值