Sobes.tech
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);
}