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?