HashMap的底层原理

HashMap的底层原理

HashMap,是基于Hash表的Map接口的非同步实现,此实现提供所有可选映射,并且允许null值和null键。此类不保证存入数据的顺序,特别是他它不保证顺序的永恒不变。

在java中所有的数据结构的构造都可以用数组和模拟指针来实现(引用),HashMap也不例外,HashMap实际上是一个“散列表列”的数据结构,就是数组和列表。

当我们往HashMap 存入一个数据的时候,它会根据key的hashcode,计算hash值,根据hash值拿到这个数据的下标,如果该下标已经存在值,那么这个位置会议链表形式存放,最先进加入的会存在链尾,新加入的存在于链头,如果该位置没有数据,则会直接存入

需要关注的一点是,在jdk8之后,对HashMap做了一个优化,当链表存储数据超过八个,该链表会转为红黑树来提高查询的速度,从源来的O(n)到O(logn)

HashSet的的底层原理

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值