微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java.util.HashSet中的contains方法不符合我的预期

如何解决java.util.HashSet中的contains方法不符合我的预期

| 这是java main()方法

    public static void main(String[] args) {

        HashSet set = new HashSet();
        Mapper test = new Mapper(\"asd\",0);
        set.add(test);

        System.out.println(new Mapper(\"asd\",0).equals(test));
        System.out.println(set.contains(new Mapper(\"asd\",0)));

    }

我的Mapper类是:
class Mapper {

String word;
Integer counter;

Mapper (String word,Integer counter) {

    this.word = word;
    this.counter = counter;

}

public boolean equals(Object o) {

    if ((o instanceof Mapper) && (((Mapper)o).word == this.word)) {

        return true;

    }

    return false;

}

}
结果是: 真正 假 从HashSet规范中,通过这种方法,我读到了以下内容:\“如果此集合包含指定的元素,则返回true。更正式地,当且仅当此集合包含元素e时,才返回true,使得(o == null?e == null :o.equals(e))。 因此,有人可以向我解释我错了吗?要么 ...? 谢谢。

解决方法

您需要实现适当的
hashCode()
函数。
public int hashCode() {
  // equal items should return the same hashcode
}
Java实用程序“ 4”包含许多依赖于哈希的类。要允许一个人覆盖他们认为合适的“ 5”,这意味着一个人也必须正确覆盖“ 2”才能匹配。 正确的实现
hashCode()
会为two5ѭ返回true的任何两个对象返回相同的哈希值。与散列相关的函数在检查对象是否相等之前检查散列是否相等(以解决散列冲突)。,hashCode合同规定,如果两个对象相等,则它们应具有相同的哈希码。像“ 9”之类的收藏都假定这是成立的。 ѭ11和ѭ12的ѭ10实现是基于地址(或对象ID)的。如果覆盖ѭ11进行内容比较,则应覆盖ѭ12来基于内容生成哈希。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。