HashMap梳理

20 篇文章 0 订阅
1 篇文章 0 订阅

实现

Java容器(四):HashMap(Java 7)的实现原理

面试常问:
HashMap的工作原理

java7和java8的区别
JDK8中,当同一个hash值的节点数不小于8时,将不再以单链表的形式存储了,会被调整成一颗红黑树.
JDK7与JDK8中HashMap的实现
Java 8系列之重新认识HashMap

HashMap与HashTable

不同(针对1.7)
1、null key和null value:HashMap的key和value都可以是null,因为它将null的hashCode值定为了0
2、容量不同:HashTable默认的初始大小为11,之后每次扩充为原来的2n+1。HashMap默认的初始化大小为16,之后每次扩充为原来的2倍。
3、key的hash:HashTable使用取余,结果会更均匀。HashMap使用位计算,速度快。
4、线程安全:HashTable是同步的HashMap不是
5、HashTable已经淘汰了,不要使用

[HashMap和HashTable到底哪不同?]http://zhaox.github.io/2016/07/05/hashmap-vs-hashtable

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值