HashTable是一个过期的集合类,在java4中呗重写了,实现了Map接口,因此也成了集合的一部分 HashTable和HashMap的主要区别是线程安全和性,同步,以及速度 1.HashMap能够接受为null的键值(key)和值(value),而Hashtable则不行 2.HashMap是非synchronized,而Hashtable是synchronized,这意味着Hashtable是线程安全的,多个线程能够共享一个Hashtable Java 5提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的扩展性更好。 3.因为Hashtable是线程安全的也是synchronized,因此在单线程环境下它比HashMap要慢。 4.HashMap不能保证随着时间的推移Map中的元素次序是不变的。 注意: 1. sychronized意味着在一次仅有一个线程可以更改Hashtable。就是说任何线程要更新Hashtable时要首先得到同步锁, 其它线程要等到同步锁被释放以后才能再次得到同步锁更新Hashtable。 2. HashMap能够经过下面的语句进行同步: Map m = Collections.synchronizeMap(hashMap);