Java8改进的HashMap和Hashtable实现类

来源:互联网 发布:1.5v单片机 温湿度测量 编辑:程序博客网 时间:2024/06/05 15:10

HashMap和Hashtable都是Map接口的典型实现类,它们之间的关系完全类似于ArrayList和Vector的关系:Hashtable是一个古老的Map实现类,它从JDK1.0起就已经出现了,当它出现时,Java还没有提供Map接口,所以它包含了两个繁琐的方法,即elements()(类似于Map接口定义的values()方法)和keys()(类似于Map接口定义的keySet()方法),现在很少使用这两个方法(关于这两个方法的用法请参考)

        Java8改进了HashMap的实现,使用HashMap存在key冲突时依然具有较好的性能。

         除此之外,Hashtable和HashMap存在两点典型区别。

        (1)Hashtable是一个线程安全的Map实现,但HashMap是线程不安全的实现,所以HashMap比Hashtable的性能高一点;但如果有多个线程访问同一个Map对象时,使用Hashtable实现类会更好。

 (2)Hashtable不允许使用null作为key和value,如果试图把null放进Hashtable中,将会引发空指针异常;但HashMap可以使用null作为key或value。

   由于HashMap里的key不能重复,所以HashMap里最多只有一个key-value对的key为null,但可以有无数多个key-value对的value为null.

下面程序示范了用null值作为HashMap的key和value的情形。

package com.zhao.three;import java.util.HashMap;public class NullInHashMap {public static void main(String[] args) {HashMap   hm=new HashMap<>();hm.put(null, null);hm.put(null, null);hm.put("a", null);System.out.println(hm);}}

      上面程序试图向HashMap中放入三个key-value对,其中第二行代码处无法将key-value对放入,因为Map中已经有一个key-value对的key为null值,所以无法再放入key为null值的key-value对。第三行代码处可以放入该key-value对,因为一个HashMap中可以有多个value为null值。编译、运行上面程序,看到如下输出结果;

0 0
原创粉丝点击