HashSet 、HashMap 和 HashTable

• HashMap 是“Java映射类(实现Map接口的类)”成员之一,继承自抽象类AbstractMap(以模板方法模式提供Map接口的基本实现),并运用Hash算法实现了映射操作。

 

• HashSet 是 “Java无序集合类(实现Set接口的类)”成员之一,继承自抽象类AbstractSet,内部基于HashMap实现了无序集合类的操作,实际上,HashSet只是运用了HashMap的“key”,“value”统一放置为HashSet类的一个静态对象。

 

• HashTable 也是Java映射类成员之一,也实现了Map接口,不过它继承自抽象类Dictionary。与HashMap相比,有以下区别:

1.Hashtable的方法是线程安全的,HashMap不具有线程安全性

2.Hashtable不允许null键和null值(如果遇到会抛出异常),HashMap允许一个null键和多个null值

(总之就是Hashtable要安全点、慢点、严格点)

 

ps:Hashtable在应用中不太常见,倒是其子类Properties用得较多,ex:

 

用Properties显示系统属性:

Properties pps = System.getProperties(); pps.list(System.out);  

 

用Properties读配置文件:

 Properties pps = new Properties(); try { pps.load(new FileInputStream("lesson6//properties.ini")); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } Enumeration enumer = pps.propertyNames(); while(enumer.hasMoreElements()) { String strKey = (String)enumer.nextElement(); String strValue = pps.getProperty(strKey); System.out.println("Key:"+strKey+" Value:"+strValue); }

你可能感兴趣的:(J2SE)