35

我有以下代码:

class C
{
    String n;

    C(String n)
    {
        this.n = n;
    }

    public String getN() { return n; }

    @Override
    public boolean equals(Object obj)
    {
        return this.getN().equals(((C)obj).getN());
    }
 }

List<C> cc = Arrays.asList(new C("ONE"), new C("TWO"), new C("ONE"));

System.out.println(cc.parallelStream().distinct().count());

但我不明白为什么distinct返回 3 而不是 2。

4

1 回答 1

52

您还需要覆盖hashCode类中的方法C。例如:

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

当两个C对象相等时,它们的hashCode方法必须返回相同的值。

接口的 API 文档Stream没有提到这一点,但众所周知,如果你覆盖equals,你也应该覆盖hashCode。API 文档Object.equals()提到了这一点:

请注意,每当重写此方法时,通常都需要重写该hashCode方法,以维护该hashCode方法的一般合同,该合同规定相等的对象必须具有相等的哈希码。

显然,Stream.distinct()确实使用了对象的哈希码,因为当你像我上面展示的那样实现它时,你会得到预期的结果:2。

于 2014-01-24T13:34:36.617 回答