您的位置:首页 > 编程语言 > Java开发

Java 中HashMap和HashTable的区别?

2016-08-16 21:46 375 查看
对于Map接口来说,它有俩种比较重要的实现类HashMap和HashTable,它们保存元素的时候,都是无序的。但是,它们也有一定的区别,适用于不同的情况。

HashTable相对于HashMap更早提出,应用也非常广泛,HashMap后来提出是为了代替HashTable的类,也就是说建议使用HashMap,不要使用HashTable。可能我们觉得HashTable很好用,为什么不用呢?这里简单分析一下它们的区别:

1.HashTable的方法时同步的,HashMap不能同步,所以在多线程场合要使用HashTable,这个区别就像Vector与ArrayList一样

2.HashTable不允许null值(key和value都不可以),HashMap允许null值(key与value都可以)。

3.HashTab有一个contains()方法,功能和containsValue()功能一样。

4.HashTable使用Enumeration遍历,而HashMap使用Iterator进行遍历

5.HashTable中hash数组默认大小是11,增加的方式是:old*2+1,HashMap中hash数组的默认大小是16,而且一定是2的指数。

6.哈希值的使用不同,HashTable直接使用对象的hashCode,而HashMap会重新计算hash值。

示例代码:

public class Test4 {

public static void main(String[] args) {
Map<String, String>map=new HashMap<>();
map.put("1", "a");
map.put("2", "b");
map.put("3", "c");
for (String key : map.keySet()) {
//用get方法来获取value
System.out.println(key+":"+map.get

(key));
}

}
}


结果如下:

3:c

2:b

1:a

说明:HashMap更符合Java集合框架的设计思路,更推荐使用。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息