java HashMap和HashTable的区别详解
作者:lqh 时间:2023-08-10 18:41:56
HashMap和HashTable,这二者的区别经常被别人问起,今天在此总结一下。
(一)继承的历史不同
public class Hashtable extends Dictionary implements Map
public class HashMap extends AbstractMap implements Map
Hashtable是继承自Dictionary类的,而HashMap则是Java 1.2引进的Map接口的一个实现。
(二)安全性不同
HashMap是非synchronized,而HashTable在默认的情况下是synchronized,这意味着HashTable是线程安全的,多个线程可以共享一个HashTable;而如果没有正确的同步的话,多个线程是不能共享HashMap的。Java 5以后提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的扩展性更好。当然,我们可以通过以下方法让HashMap同步:
Map m = Collections.synchronizeMap(hashMap);
(三)是否可为空值的异同
HashMap可以让你将空值作为一个表条目的key或value。HashMap中只有一条记录可以是一个空的key,但任意数量的条目可以是空的value。这就是说,如果在表中没有发现搜索键,或者如果发现了搜索键,但它是一个空的值,那么get()将返回null;而HashTable则不行,key和value都不允许出现null值。
(四)二者的遍历方式的内部实现上不同
Hashtable、HashMap都使用了 Iterator迭代器,HashMap的迭代器(Iterator)是fail-fast迭代器,而HashTable的enumerator迭代器不是fail-fast的。而由于历史原因,Hashtable还使用了Enumeration的方式 。
(五)哈希值的使用不同
HashTable直接使用对象的hashCode,而HashMap则需要重新计算hash值。
(六)二者内部实现方式的数组的初始大小和扩容的方式不同
HashTable中hash数组默认大小是11,增加的方式是 old*2+1;HashMap中hash数组的默认大小是16,而且一定是2的指数。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
来源:http://blog.csdn.net/mynameishuangshuai/article/details/52748731
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Windows 10卸载JDK1.8超详细图文教程
![](https://img.aspxhome.com/file/2023/9/98399_0s.jpg)
Android XListView下拉刷新和上拉加载更多
![](https://img.aspxhome.com/file/2023/8/126698_0s.gif)
Android仿美团淘宝实现多级下拉列表菜单功能
![](https://img.aspxhome.com/file/2023/4/137114_0s.png)
Java BeanPostProcessor与BeanFactoryPostProcessor基础使用讲解
C++定义和初始化string对象实例详解
Java实现拖拽列表项的排序功能
在Spring中自动装配Bean的属性
JSON各种转换问题(json转List,json转对象等)
分析Android内存泄漏的几种可能
![](https://img.aspxhome.com/file/2023/1/110721_0s.png)
Android 应用签名的两种方法
Java中的this和super实例浅析
java8中parallelStream性能测试及结果分析
Kotlin 使用Lambda来设置回调的操作
![](https://img.aspxhome.com/file/2023/3/96033_0s.jpg)
解决Spring国际化文案占位符失效问题的方法
分享安装Android Studio3.6的经验教训
![](https://img.aspxhome.com/file/2023/4/137424_0s.png)
C# 关于LoadLibrary的疑问详解
Spring之WEB模块配置详解
Jetpack Compose实现列表和动画效果详解
![](https://img.aspxhome.com/file/2023/3/103893_0s.png)