Hashtable继承了Dictionary,是线程安全的,键值对中不能出现null。
Hashmap实现了Map接口,是Hashtable的轻量级实现(非线程安全的实现),即多个线程访问Hashmap时需要为其准备外同步,且Hashmap的键、值均可以为null。
遍历map有两种方式:keyset(效率低)和entryset(效率高),两种方式都需要创建Iterator迭代器对象,不同的是使用keyset需要从迭代器中获取map的key,并且通过key获取value(key=iterator.next(); value=map.get(key));使用entryset则需要从迭代器中获取Map.Entry对象,再从中获取map的key和value(Map.Entry entry=(Map.Entry)iterator.next(); key=entry.getKey(); value=entry.getValue())。
Map map=new HashMap();
Iterator iterator=map.entrySet().iterator();
while(iterator.hasNext()){
Map.Entry entry=(Map.Entry)iterator.next();
Object key=entry.getKey();
Object value=entry.getValue();
}
Map map=new HashMap();
Iterator iterator=map.keySet().iterator();
while(iterator.hasNext()){
Object key=iterator.next();
Object value=map.get(key);
}