包含集合的java类的哈希码实现

Aar*_*ron 3 java hashcode

我有一个包含集合的类.如果集合的内容相等,则类的两个实例是相等的.在构建数据结构时,我将类存储在HashSet中,并且集合的内容也会发生变化.这些更改会导致哈希码值发生更改.这似乎会导致我的数据在Set中丢失的副作用.从哈希码计算中删除集合可以解决问题,但违反了规则,其中equals中的所有字段都应该在哈希码中使用.

在这种情况下,您将如何实现哈希码?

public class LeveZeroHolder
{
private final Set<LevelOneHolder> orgGroups = new HashSet<LevelOneHolder>();
private final String name;

public LeveZeroHolder(String name, LevelOneHolder og)
{
    this.name = name;
    orgGroups.add(og);
    og.setFA(this);
}

@Override
public boolean equals(Object obj)
{
    if (this == obj)
        return true;
    if (obj == null || obj.getClass () != getClass ())
        return false;

    LeveZeroHolder hobj = (LeveZeroHolder)obj;
    return getOrgGroups().equals(hobj.getOrgGroups()) && getName().equals(hobj.getName());
}

@Override
public int hashCode()
{
    int rs = 17;
    rs = rs * 37 + ((getName() == null) ? 0 : getName().hashCode ());
    rs = rs * 37 + ((getOrgGroups() == null) ? 0 : getOrgGroups().hashCode());
    return rs;
}

public String getName()
{
    return name;
}

public Set<LevelOneHolder> getOrgGroups()
{
    return orgGroups;
}

public void addOrgGroup(LevelOneHolder o)
{
    o.setFA(this);
    orgGroups.add(o);
}
}
Run Code Online (Sandbox Code Playgroud)

ass*_*ias 5

如果你的意思是当你将这些对象存储为Map或Set中的键时它们会丢失,你可能想要看看这个线程,这解释了为什么在一个集合中存储可变对象并不是一个好主意,特别是如果他们在被集合所持有的时候会改变.

Setjavadoc中提取:

注意:如果将可变对象用作set元素,则必须非常小心.如果在对象是集合中的元素的同时以影响等于比较的方式更改对象的值,则不指定集合的​​行为.这种禁令的一个特例是,不允许集合将自身作为一个要素包含在内.