当HashSet调用等于方法?

时间:2014-02-07 11:39:47

标签: java

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

当我运行这个时,我得到了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方法时

1 个答案:

答案 0 :(得分:4)

您的代码只会拨打equals() HashTest一次。它调用equals()方法的另一个时间是equals()类的String

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

This answer解释equals()方法何时被HashSet调用,何时不是{{1}}方法。摘录自:

  

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