Java集合——HashMap与Hashtable的区别

共同点:

都是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要旧

你可能感兴趣的:(JavaSE)