A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 谢明 中级黑马   /  2012-3-9 13:58  /  3230 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

Set 里的元素是不能重复的,那么用什么方法来区分重复与否呢?

5 个回复

倒序浏览
加入Set里面的元素必须定义自己的equals()方法,但是对于良好的设计风格,最好在覆盖equals()方法的同时,也覆盖hashCode()方法。往Set中插入心的对象时会用该对象的hashcode()与已经存在的对象的hashcode()比较,相等则不能添加,不相等的话,才会调用equals方法。其中的hashSet是必须实现hashcode()方法的,放入的对象是以hashcode值来标示的。
回复 使用道具 举报
set里的元素是不复能重复的,equals是用来判断是否引用同一个对象。set里面存放的是对象的引用,所以当两个元素只要满足了equals()时就已经指向同一个对象,
也就出现了重复元素。所以应该用equals()来判断。

回复 使用道具 举报
{:soso_e113:} 嗯嗯
回复 使用道具 举报
set存储元素是无存储顺序的,而且不重复, 要去重复,就是equals()方法.是比较两个元素是否相同 equals 方法是String类从Object类中继承,被用来检测两个对象是否相等,也就是两个对象的内容是否相等。
回复 使用道具 举报
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;
    }

评分

参与人数 1技术分 +1 收起 理由
admin + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马