Back to questions
Junior — Middle
67
Каким образом реализовать метод вычисления уникального хеша объекта в Java?
Companies where asked
ПСБ
Answer from AI
sobes.tech AI
В Java для вычисления уникального хеша объекта обычно переопределяют метод hashCode(). Важно, чтобы:
- Если два объекта равны (
equals()возвращаетtrue), то их хеши должны совпадать. - Хороший хеш должен равномерно распределять значения, чтобы уменьшить коллизии.
Пример реализации для класса Person с полями name и age:
public class Person {
private String name;
private int age;
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Person person = (Person) o;
return age == person.age && name.equals(person.name);
}
@Override
public int hashCode() {
int result = name.hashCode();
result = 31 * result + age;
return result;
}
}
Здесь используется простая формула с множителем 31, которая широко применяется в Java для вычисления хеша.
Также можно использовать Objects.hash() для упрощения:
@Override
public int hashCode() {
return Objects.hash(name, age);
}