谈谈你对HashMap中put/get方法的认识?如果了解再谈谈HashMap的扩容机制?默认大小是多少?什么是加载因子(或填充比)?什么是吞吐临界值(或阈值、threshold)?

此图是jdk7的图解

jdk7的文字描述(会在中间介绍一些8的改变):

  • 将key1,value1(就是一个键值对Entry)添加到数组中,首先根据key1所在累的hashCode()方法计算key1的哈希值1,然后使用某种算法,得到哈希值2,(个人理解是两次计算哈希值是为了让得到的哈希值相同的概率更小些),哈希值2在使用indexFor()
    方法得到底层table数组中存放的位置:index(0<=index &&index <= 15);
    【1.在jdk8中,当使用了空参构造器创建对象时,底层并没有创建长度为16的数组,2.而是当我们首次调用put()函数时底层才会首先创建长度为16的数组,3.底层创建的数组为:Node[](classNode implements Map.Entry{},这里与jdk7有所不同】

  • 如果index位置没有元素,则直接把key1,value1这个键值对添加进去(添加成功1)</

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值