1、典型回答
HashMap 和 Hashtable 都实现了 Map 接口,都是用来存储键值对的数据结构。
它们的区别主要有以下几点:
- 线程安全性: HashMap 是非线程安全的,而 Hashtable 是线程安全的
- null 键和 null 值的支持: HashMap 允许键和值都为 null,即可以插入 null 键和 null 值; 而 Hashtable 不允许键或值为 null,如果尝试插入 null 键或 null 值,会抛出NullPointerException。
- **性能:**由于 HashMap 不是线程安全的,在单线程环境下通常有更好的性能。Hashtable 是线程安全的,但会带来额外的同步开销,因此在单线程环境下性能可能较差。
2、全面剖析
HashMap 和 Hashtable 都实现了 Map 接口,都是用来存储键值对的数据结构
Hashtable 诞生于JDK 1.0,而 HashMap 诞生于JDK 1.2,是用来在单线程下替代 Hashtable 的,而在多线程下要使用 ConcurrentHashMap 替代 Hashtable。
HashMap 和 Hashtable 的区别主要线程安全不同,Hashtable 使用了 synchronized 修饰方法,所以它是线程安全的,而 HashMap 是非线程安全的, 又因为 Hashtable 使用 synchronized 加锁,所以在单线程下,它的性能不如HashMap;最后是 HashMap 支持键、值都允许插入 null,而 Hashtable 不允许 nul 键或 nul值.
3、知识扩展
为什么 Hashtable 不允许插入 null 键和 null 值