黑马程序员技术交流社区

标题: 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