赞
踩
HashSet 底层就是基于 HashMap 实现的。(HashSet 的源码非常非常少,因为除了 clone() 方法、writeObject()方法、readObject()方法是 HashSet 自己不得不实现之外,其他方法都是 直接调用 HashMap 中的方法。)
1.实现接口不同:
HashMap实现了Map接口,HashSet实现了set接口。
2.存储内容不同:
HashMap存储的是键值对,HashSet存储的是对象。
3.添加元素的方法不同:
HashMap调用put()方法向map中添加元素
HashSet调用add()方法向map中添加元素
4.计算hashCode的方式不同
HashMap使用键(key)来计算hashCode
HashSet使用成员对象来计算hashcode的值,对于两个对象来说,他们的hashcode值可能相同,所以用equals()方法来判断对象的相等性。如果两个对象不相等的话返回false
5.效率
HashMap相对于HashSet较快,因为它是使用唯一的键获取对象。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。