Java中,ArrayList的contains()和HashSet的contains()的区别,哈希值问题

今天我看源码前者是for循环equals.后者貌似是比较哈希值.假如:classFoo(){}HashSetset=newHashSet();set.add(newFoo... 今天我看源码前者是for循环equals.后者貌似是比较哈希值.
假如:
class Foo() {
}
HashSet set = new HashSet();
set.add(new Foo());
set.contains(new Foo());
结果为false.为什么..
我输出两个string(都是new String("a")),他们的哈希值是一样的..
但是我输出两个类都是直接new新的..哈希值是不一样的..
有什么区别么.
是不是因为没有重写Foo
中hashcode和equals方法。
展开
 我来答
dl_eny
2011-08-20 · 超过19用户采纳过TA的回答
知道答主
回答量:63
采纳率:0%
帮助的人:50.9万
展开全部
ArrayList与HashSet都是Collections类的子类,Collection类提供了许多常用的方法,例如contains()就是其中一个!我没有看过这两个类的contains()具体是如何实现的,但是通过数据结构我觉得应该是这个样子,ArrayList也就是一个数组,遍历整个数组,如果数组中存在这样一个元素equals(Object obj);那么就是true否则返回false.而HashSet的话,只需要比较key就能确定是否含有该元素了!
eaquals()为true的话,一定有相同的HashCode的!
费和平啊
2011-08-20 · 超过26用户采纳过TA的回答
知道答主
回答量:79
采纳率:0%
帮助的人:74.6万
展开全部
没有什么区别 都是检索值是否子集合中出现过
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友b25f5f8
2011-08-20 · TA获得超过203个赞
知道小有建树答主
回答量:480
采纳率:0%
帮助的人:222万
展开全部
你虽然是new了2个Foo();咋一看是相同的,但是他们是指向不同的值域
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式