HashMap 和 Hashtable 的区别?【面试题详解】

今天爱分享给大家带来HashMap 和 Hashtable 的区别?【面试题详解】,希望能够帮助到大家。
HashMap 是 Hashtable 的轻量级实现(非线程安全的实现),他们都实现 Map 接口,主
要区别在于 HashMap 允许空(null)键值(key),由于非线程安全,在只有一个线程访问的
情况下,效率要高于 Hashtable。
HashMap 允许将 null 作为一个 entry 的 key 或者 value,而 Hashtable 不允许。
HashMap 把 Hashtable 的 contains 方法去掉了,改成 containsvalue 和 containsKey。因为
contains 方法容易让人引起误解。
Hashtable 继承自 Dictionary 类,而 HashMap 是 Java1.2 引进的 Map interface 的一个实
现。
最大的不同是,Hashtable 的方法是 synchronized 的,而 HashMap 不是,在多个线程访问
Hashtable 时,不需要自己为它的方法实现同步,而 HashMap 就必须为之提供外同步。
Hashtable 和 HashMap 采用的 hash/rehash 算法都大概一样,所以性能不会有很大的差异。

人已赞赏
Java

简述 synchronized 和 java.util.concurrent.locks.Lock 的异同 ?【面试题详解】

2020-12-2 16:52:21

Java

List、Set、Map 是否继承自 Collection 接口?【面试题详解】

2020-12-2 16:53:20

'); })();