前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >HashMap和HashTable的区别

HashMap和HashTable的区别

原创
作者头像
ruochen
修改2021-11-24 14:13:10
2090
修改2021-11-24 14:13:10
举报
文章被收录于专栏:若尘的技术专栏

1、线程是否安全:

HashMap是非线程安全的,HashTable是线程安全的;HashTable内部的方法基本上都经过synchronized修饰。(如果你要保保证线程安全监视使用ConcurrentHashMap);

2、效率: 因为线程安全的问题,HashMap要比HashTable的效率高一些,另外HashTable基本被淘汰,不建议在代码中使用;

3、对Null key和Null value的支持:

在HashMap中Null可以为主键,但这样的键只能有一个,可以有一个或多键所对应的值为null。但是在HashTable中put进的键值只要有一个null,直接抛出NullPointerException;

4、初始容量大小和每次扩容容量大小不同:

创建时如果不指定容量的初始值,HashMap默认的初始化大小为16,之后每次扩容容量变为原来的两倍。HashTable默认的初始大小为11,之后每次扩容,容量变为原来的2n+1;创建时如果给定了容量的初始值,那么HashTable会直接使用你给定的大小,而HashMap会将其扩充为2的幂次方大小;

5、底层数据结构:

JDK1.8以后的HashMap在解决哈希冲突时有了较大的变化,当链表长度大于阈值(默认为8)时,将链表转化为红黑树,以减少搜索时间。HashTable没有这样的机制;

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
作者已关闭评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档