HashSet何时调用equal方法?[英] When HashSet call equal method?

问题描述

我在一个教程中找到了这个例子.

当我运行这个时,我得到 hs.size() 值为 2 ..并且 equals 方法只被调用一次 任何人解释我在 HashSet 中调用 equal() 方法时

import java.util.HashSet;

public class HashTest {
    private String str;

    public HashTest(String str) {
        this.str = str;
    }

    @Override
    public String toString() {      
        return str;
    }

    @Override
    public int hashCode() {             
        return this.str.hashCode();
    }

    @Override
    public boolean equals(Object obj) { 
        System.out.println("calling equal method");
        if (obj instanceof HashTest) {

            HashTest ht = (HashTest) obj;
             System.out.println(ht.str);
            return this.str.equals(ht.str);
        }
        else
        {
            System.out.println("Not equal");
        }
        return false;
    }

    public static void main(String args[]) {
        HashTest h1 = new HashTest("1");
        HashTest h2 = new HashTest("1");
        String s1 = new String("2");
        String s2 = new String("2");

        HashSet<Object> hs = new HashSet<Object>();
        hs.add(h1);
        hs.add(h2);
        hs.add(s1);
        hs.add(s2);

        System.out.print(hs.size());
    }
}

上述程序中equal方法调用时

推荐答案

你的代码只会调用 HashTest 的 equals() 一次.它调用 equals() 方法的另一次是 String 类的 equals().

hs.add(h1); // Nothing is called
hs.add(h2); // Calls the equals() method of HashTest, thus the log
hs.add(s1); // Nothing is called
hs.add(s2); // Calls the equals() method of String

这个答案解释了 HashSet 何时调用 equals() 方法,何时不调用.摘录:

<块引用>

HashSet 利用哈希码来加快速度.它假设两个相等的对象将具有相同的哈希码.但是,它并不假定具有相同哈希码的两个对象意味着它们是相等的.这就是为什么当它检测到冲突的哈希码时,它只会与集合中具有相同哈希码的其他对象(在您的情况下为一个)进行比较.

本文地址:https://www.itbaoku.cn/post/978497.html