(1)HashTable的方法是同步的,HashMap不同步,所以在多线程情况下,使用的是HashTable
(2)HashTable不允许null值(key和value都不可以),HashMap允许null值(key和value都可以)
(3)HashTable有一个contains()方法,功能和containsValue()功能一样
(4)HashTable使用Enumeration遍历,HashMap使用Iterator遍历
(5)HashTable中数组默认大小是11,增加方式是old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。
(6) Hash值得使用不同,HashTable直接使用对象的hashCode,而HashMap会重新计算hash值。
public class HashMapTest {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Map<String, String> map = new HashMap<String, String>();
map.put("a", "123");
map.put("b", "345");
map.put("c", "456");
for (String key : map.keySet()) {
System.out.println(key + ":" + map.get(key));
}
//System.out.println(map.keySet());
}
}