Библиотека собеса по Java | вопросы с собеседований
6.33K subscribers
398 photos
9 videos
472 links
Вопросы с собеседований по Java и ответы на них.

По рекламе: @proglib_adv

Учиться у нас: https://proglib.io/w/08c603b6

Для обратной связи: @proglibrary_feeedback_bot
Download Telegram
Для чего нужна HashMap?



HashMap нужна исключительно для того, чтобы было что спросить на собеседовании. Без неё интервьюеры бы не знали, как отсеивать кандидатов.

✔️

HashMap — это реализация структуры данных hash table, которая обеспечивает быстрый доступ, вставку и удаление элементов по ключу в среднем за O(1).

Основные сценарии использования:

1️⃣ Кеширование и мемоизация — когда нужен быстрый доступ к часто используемым данным.

2️⃣ Подсчет частоты элементов — классическая задача с O(n) сложностью.

3️⃣ Индексация для быстрого поиска — когда нужно избежать линейного перебора.

🐸 Библиотека собеса по Java

#core
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8😁3🔥1🥱1
Почему нельзя использовать LocalDateTime для работы с временными метками в распределенных системах?



Потому что LocalDateTime — это местное время, а в распределенных системах все серверы находятся в разных городах! Если один сервер в Москве показывает 15:00, а другой в Владивостоке — 22:00, то база данных не знает, как решить противоречия.

✔️

LocalDateTime не хранит информацию о часовом поясе и смещении относительно UTC, что делает его непригодным для распределенных систем

🐸 Библиотека собеса по Java

#core
Please open Telegram to view this post
VIEW IN TELEGRAM
👍111🔥1🤔1
В чем разница между fail-fast и fail-safe итераторами?



Fail-fast итераторы — это те, которые быстро падают при первой же ошибке, потому что написаны на скорострельном C++. А fail-safe итераторы работают медленно, зато безопасно, потому что каждый элемент проверяется антивирусом перед возвратом.

✔️

🔹 Fail-fast итераторы:

Бросают ConcurrentModificationException при структурном изменении коллекции во время итерации.
Проверяют modCount (счетчик модификаций) при каждом вызове next().
Используются в большинстве коллекций из java.util (ArrayList, HashMap, HashSet).
Работают на оригинальной коллекции.

🔹 Fail-safe итераторы:

Работают на копии/снимке коллекции, поэтому не бросают исключений.
Используются в java.util.concurrent коллекциях (CopyOnWriteArrayList, ConcurrentHashMap).
Могут не отражать актуальное состояние коллекции (weakly consistent).
Потребляют больше памяти из-за копирования.

🐸 Библиотека собеса по Java

#core
Please open Telegram to view this post
VIEW IN TELEGRAM
👍6😁2🔥1