HashMap和HashTable的区别

时间:2021-7-3 作者:qvyue

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

声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:qvyue@qq.com 进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。