Czy funkcja hashCode generowana przez Eclipse jest dobra?

Menu źródłowe Eclipse ma „metodę hashCode / equals”, która generuje funkcje takie jak poniżej.

String name; 
@Override
public int hashCode()
{
    final int prime = 31;
    int result = 1;
    result = prime * result + ((name == null) ? 0 : name.hashCode());
    return result;
}

@Override
public boolean equals(Object obj)
{
    if (this == obj)
        return true;
    if (obj == null)
        return false;
    if (getClass() != obj.getClass())
        return false;
    CompanyRole other = (CompanyRole) obj;
    if (name == null)
    {
        if (other.name != null)
            return false;
    } else if (!name.equals(other.name))
        return false;
    return true;
}

Jeśli wybieram wiele pól podczas generowaniahashCode() iequals() Eclipse używa tego samego wzoru pokazanego powyżej.

Nie jestem ekspertem od funkcji skrótu i ​​chciałbym wiedzieć, jak „dobra” jest wygenerowana funkcja skrótu? Jakie są sytuacje, w których ulegnie awarii i spowoduje zbyt wiele kolizji?

questionAnswers(8)

yourAnswerToTheQuestion