剖析hashmap

今天来看看java中的hashmap,提到hashmap,我们会想到另一个类,没错那就是hashtable,它们之间的区别在此就不多说了,hashmap是允许key和value为null,而且它是非同步的。今天我们主要看看hashmap中影响hashmap执行性能的两个关键参数。

这两个参数是initialCapacity和loadfactor,capacity是hash表中buckets的数量,initialCapacity是hashmap创建时capacity的大小,loadfactor是作为hash表空间大小的一个评估。当hash表中的entries数量超过loadfactor与当前capacity的乘积时hash表将被rehashed(对内部数据重新组装)。

1、initialCapacity

为hashmap的初始容量,若未设置该值的话,还有一个参数为default_initial_capacity=16(调用无参构造函数时),如果hash函数在buckets间合理的传播元素,hashmap为一些常规的方法提供了固定时间性能操作(如get,put)。但若遍历集合视图就必须要求时间和hashmap的capacity大小(buckets的数量)相对称,再加上它的尺寸(key-value对的数量),因此,不要把capacity设置的太大或者不要把loadfactor设置的太小都是十分重要的,否则的话就会影响迭代的性能。

2、loadFactor

默认值为0.75,因为这个值在时间和空间消耗上提供了一个很好的权衡,高于这个值时虽然减少了日常空间的消耗,但是会增加检查的消耗(put,get调用时)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值