共同点:
都是Java 的集合类,都可以用来存放Java对象。
不同点:
1、HashMap是非线程安全的。
HastMap是一个接口 是map接口的子接口,是将键映射到值的对象,其中键和值都是对象。HashMap允许null Key,null Value,而Hashtable是不允许的。
2、Hashtable是线程安全的一个Coillection。
具体来说:
A、HastMap 是Hashtable轻量级的应用实现(非线程安全的应用实现)。他们都完成了Map接口,其区别在于Map允许null Key ,null Value ,由于非线程安全,因此运行效率上会高于Hashtable。
B、Hashtable不允许允许将null作为一个entry的key或者value。 HashMap是把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因为contains方法容易让人引起误解。
C、最大的不同:Hashtable的方法Synchronize 的,因此是线程安全的;HashMap的方法不是Synchronize的,因此是非线程安全的。
D、Hashtable和HashMap采用的hash/rehash算法大概一样,所以性能不会有很大的差。
总结:
HashMap | 非线程安全 | 允许有null的键和值 | 效率高一点 | 方法不是Synchronize的, 要提供外同步 | 有containsvalue和 containsKey方法 | HashMap 是Java1.2 引进的 Map interface 的一个实现 | HashMap是Hashtable 的轻量级实现 |
Hashtable | 线程安全 | 不允许有null的键和值 | 效率稍低 | 方法是是Synchronize的 | 有contains方法方法 | Hashtable 继承于 Dictionary 类 | Hashtable比HashMap要旧 |