黑马程序员技术交流社区
标题:
Set中不可重复的判断方法
[打印本页]
作者:
谢明
时间:
2012-3-9 13:58
标题:
Set中不可重复的判断方法
Set 里的元素是不能重复的,那么用什么方法来区分重复与否呢?
作者:
吴璞玉
时间:
2012-3-9 14:20
加入Set里面的元素必须定义自己的equals()方法,但是对于良好的设计风格,最好在覆盖equals()方法的同时,也覆盖hashCode()方法。往Set中插入心的对象时会用该对象的hashcode()与已经存在的对象的hashcode()比较,相等则不能添加,不相等的话,才会调用equals方法。其中的hashSet是必须实现hashcode()方法的,放入的对象是以hashcode值来标示的。
作者:
熊玖帅
时间:
2012-3-9 14:24
set里的元素是不复能重复的,equals是用来判断是否引用同一个对象。set里面存放的是对象的引用,所以当两个元素只要满足了equals()时就已经指向同一个对象,
也就出现了重复元素。所以应该用equals()来判断。
作者:
谢明
时间:
2012-3-9 16:56
{:soso_e113:} 嗯嗯
作者:
a504079589
时间:
2012-3-9 18:45
set存储元素是无存储顺序的,而且不重复, 要去重复,就是equals()方法.是比较两个元素是否相同 equals 方法是String类从Object类中继承,被用来检测两个对象是否相等,也就是两个对象的内容是否相等。
作者:
刘蕴学
时间:
2012-3-9 18:59
Set.contains(Object o)
实现原理为
final Entry<K,V> getEntry(Object key) {
int hash = (key == null) ? 0 : hash(key.hashCode());
for (Entry<K,V> e = table[indexFor(hash, table.length)];
e != null;
e = e.next) {
Object k;
if (e.hash == hash &&
((k = e.key) == key || (key != null && key.equals(k))))
return e;
}
return null;
}
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2