HashMap和hashTabel的区别

两者最大的区别是tabel是线程同步的,而map不是。

  • 线程安全来看,HashMap不是线程安全的,在多线程情况下可能遇到并发问题,hashTable是线程安全的,但是通过内部方法添加syn来解决的,效率低下,而且在官方注释中hashTable是保留类,不建议使用。如需要线程安全可使用ConcurrentHashMap。

  • 结构上,hashTable一直是数组和链表结构,而hashMap在1.8时改为了数组和链表及红黑树。

  • 遍历上,HashTable使用Enumeration,HashMap使用Iterator。

  • 储存支持上,hashMap可以允许一个空健和多个空值,会把 null 转化为 0 进行存储,而hashTable由于需要保证线程安全的特性,不允许任何空。否则会造成歧义,即:这个key到底是存在还是不存在。

  • 容量上,hashTable默认为11,扩容为2n+1,而hashMap默认为16,扩容为2倍。如添加指定长度,table会直接使用,而map总会扩充为2的n次幂。

  • 散列算法上,上HashTable会使用key对hashCode对长度取模,hashMap会做一些扰动来达到更好的分布。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值