Sobes.tech
Back to questions
Senior
6

Что происходит если hashCode() всегда возвращает 0? Все элементы попадают в один бакет, HashMap расширяется — поможет ли это?

Companies where asked
01.tech

Answer from AI

sobes.tech AI

Если метод hashCode() всегда возвращает 0, то все объекты будут попадать в один и тот же бакет (корзину) в HashMap. Это приводит к тому, что структура данных деградирует до связного списка внутри этого бакета.

В результате операции поиска, вставки и удаления перестают быть близкими к O(1) и становятся O(n), где n — количество элементов в карте.

Расширение HashMap (увеличение количества бакетов) в этой ситуации не поможет, так как все элементы всё равно будут попадать в один бакет из-за одинакового хэш-кода. Таким образом, производительность будет ухудшаться с ростом количества элементов.

Пример:

class BadHash {
    @Override
    public int hashCode() {
        return 0;
    }

    @Override
    public boolean equals(Object obj) {
        return this == obj;
    }
}

// Использование
Map<BadHash, String> map = new HashMap<>();
map.put(new BadHash(), "value1");
map.put(new BadHash(), "value2");
// Все элементы в одном бакете, поиск медленный