阅读 95

HashMap和HashTable的区别

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没有这样的机制;

作者:HACKL

原文链接:https://www.jianshu.com/p/70baab71957d

文章分类
后端
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐