HashMap和Hashtable的区别?

HashMapHashtable的区别类似于ArrayListVector的区别。

HashtableVector都是JDK 1.0就有一个一个古老的集合,因此Hashtable是一个继承自Dictionary的古老集合。

从JDK 1.2引入集合框架的Map接口之后,JavaHashtable也实现了Map接口,因此Hashtable也新增实现了一些Map接口中定义的方法。实际上HashtableHashMap底层的实现很相似,它们都是基于Hash表的实现。

HashMapHashtable的区别主要有如下两点:

AHashMap允许使用null作为keyvalue,而Hashtable不允许。

BHashMap是线程不安全的,因此性能较好;但Hashtable是线程安全的,因此性能较差。

实际上,实际在多线程环境下,Java提供了Collections工具类把HashMap包装成线程安全的类,因此依然应该使用HashMap,如下代码所示:

Map map = Collections. synchronizedMap(new HashMap());

简单的说,编程时应该尽量避免使用Hashtable,除非在一个古老的API中强制要求Hashtable

posted @ 2020-12-07 00:32  咔啡  阅读(114)  评论(0编辑  收藏  举报