这是一个面试经常遇到的知识点,无论什么公司这个知识点几乎是考小白必备,为什么呢?因为这玩意儿太特么常见了,常见到你写一百行代码,都能用到好几次,不问这个问哪个。so!本小白网罗天下HashMap与HashTable知识重点只是为应对面试官各种神奇提问方式。
最常见的莫过于,问他们的区别了:
其实API中给出了一句相当简短的介绍,在介绍HashMap的一章中,原文是这么说的
【
基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用 null 值和 null 键。(除了非同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同。)此类不保证映射的顺序,特别是它不保证该顺序恒久不变。
】
【
public class HashMap<K,V>extends AbstractMap<K,V>implements Map<K,V>, Cloneable, Serializable
public class Hashtable<K,V>extends Dictionary<K,V>implements Map<K,V>, Cloneable, Serializable
】
好吧,大家看到了其实区别无外乎三点,(吐槽一下,竟然是在括号中附带的,尼玛这竟然成了重点),好了言归正传。
第一点:非同步,别想多了,早就说了内容摘自HashMap,当然是HashMap非同步了。
第二点:允许使用null,在API 中,HashMap 无论是键,还是值都可以是null,而HashTable中给出的是【任何非null对象都可以作为其键或者值】。
第三点:继承的类有所不同。HashMap继承自AbstractMap、HashTable继承自Dictionary。
第四点:这由第一点引申而来的,非同步意味着非线程安全,而HashTable是线程安全的,但是处理效率上来说,HashMap优于HashTable。
区别几乎就这么多日后再查到了补上: