ООП [11.03%]1. Что такое ООП? [3.31%]2. Плюсы и минусы ООП [0.37%]3. Принципы ООП (наследование, инкапсуляция, полиморфизм, абстракция) [9.93%]4. Класс, объект, интерфейс [0.37%]5. Ассоциация, агрегация, композиция [1.1%]6. Статическое и динамическое связывание [1.1%]7. Является – «is a», имеет – «has a» [0.37%]SOLID [19.49%]1. Что такое SOLID (каждая буква)? [19.12%]2. Какие принципы можешь назвать? [1.1%]3. Когда мы можем нарушать принципы SOLID? [1.1%]Java Core [66.91%]1. Расскажи мне про контракт и свойства Equals & Hashcode [19.85%]2. Что такое коллизия? [4.04%]3. Какие типы ссылок существуют в Java? [3.68%]4. Какой класс называют Immutable? [11.4%]5. Основная идея языка [0%]6. За счет чего обеспечена кроссплатформенность? [0.37%]7. Плюсы и минусы Java? [0%]8. JVM, JRE, JDK, JIT [2.21%]9. Что такое байт-код? [0.74%]10. Что такое сборщик мусора (garbage collector)? [7.72%]11. Как работает GC? [13.97%]12. Какие виды GC знаешь? [6.62%]13. Области памяти Java. Stack и heap. Что это такое? [16.54%]14. Типы данных в Java [1.1%]15. Что такое класс-обертка? [2.94%]16. Автоупаковка и автораспаковка [0.37%]17. Строки/String в Java? Из чего состоит? Нюансы [6.62%]18. Что такое пул строк/String pool? [8.82%]19. Почему не рекомендуется изменять строки в цикле? [0.37%]20. Разница между String, StringBuffer, StringBuilder [4.78%]21. Каким образом переменные передаются в методы — по значению или по ссылке? [2.21%]22. Что такое enum? [1.1%]23. Что такое конструктор? [1.47%]24. Какие есть модификаторы доступа? Какие применимы к классам? [2.94%]25. Что означает static? [5.15%]26. Можно ли сузить уровень доступа или тип возвращаемого значения при переопределении метода? [0.37%]27. Что можно изменить в сигнатуре метода при переопределении? Можно ли менять модификаторы (throws и т. п.)? [0.37%]28. Что означает модификатор final? К чему он может быть применим? [7.72%]29. Что такое абстрактные классы? [2.57%]30. Что такое интерфейсы? [2.57%]31. Отличия интерфейса от абстрактных классов? [14.34%]32. Каков порядок вызова конструкторов и блоков инициализации с учетом иерархии классов? [1.84%]33. Зачем нужны и какие бывают блоки инициализации? [0.37%]34. Для чего в Java используются статические блоки инициализации? [0.37%]35. Класс Object и его методы? [4.41%]36. Что такое сериализация и для чего она нужна? [1.1%]37. Разница между версиями Java [0.37%]38. Может ли абстрактный класс быть final? [0.37%]39. Integer pool [1.47%]40. Какие виды загрузчиков классов ты знаешь? [0.37%]41. Record-ы с Java 17. Для чего и зачем? [1.47%]42. Что такое Анонимный класс [1.84%]43. Расскажи что делает JIT компилятор [2.57%]44. Расскажи про прогрев JVM [0.37%]45. break vs continue в цикле [0.74%]46. Что такое аннотация? Зачем нужна? Как создать свою аннотацию? [4.04%]47. Переопределение и перегрузка методов [4.78%]48. ClassLoader в Java [3.68%]49. В чем разница сравнений по equals и "=="? [2.94%]Коллекции [56.99%]1. Расскажите как выглядит иерархия коллекций [22.43%]2. Что такое ArrayList? [5.51%]3. ArrayList. Какая размерность массива по умолчанию? [0.37%]4. ArrayList. Что происходит под капотом при добавлении/удалении элемента в начало/середину/конец списка? [5.51%]5. ArrayList - сложность операций [4.41%]6. Что такое LinkedList? [2.57%]7. LinkedList. Что происходит под капотом при добавлении/удалении элемента в начало/середину/конец списка? [3.68%]8. LinkedList - сложность операций [3.31%]9. ArrayList vs LinkedList [18.75%]10. Какая скорость вставки в ArrayList и LinkedList [3.68%]11. Что такое TreeMap? [2.94%]12. TreeMap - сложность операций [1.84%]13. Внутреннее устройство TreeMap [3.31%]14. Что такое HashMap? [9.56%]15. Внутреннее устройство HashMap [17.28%]16. Что такое бакет? Внутреннее устройство бакета [6.25%]17. HashMap - сложность операций [11.76%]18. Процесс добавления объекта в HashMap [12.13%]19. Будет ли работать HashMap, если все добавляемые ключи будут иметь одинаковый hashCode()? [13.97%]20. Ключи в HashMap [6.62%]21. Могу положить в HashMap или TreeMap элемент с ключом null? [2.21%]22. Что такое HashSet? [4.04%]23. Как HashSet связан с HashMap? [0.74%]24. Внутреннее устройство HashSet [2.57%]25. HashSet - сложность операций [1.47%]26. Процесс добавления объекта в HashSet? [1.1%]27. Будет ли работать HashSet, если все добавляемые элементы будут иметь одинаковый hashCode()? [0.37%]28. Что такое TreeSet? Внутреннее устройство [3.68%]29. Что такое Queue? [0.74%]30. Queue - сложность операций [0%]31. Назовите главные реализации Queue [0.37%]32. Что такое Deque? [0.37%]33. Назовите главные реализации Deque [0%]34. Deque - сложность операций [0%]35. Какая коллекция реализует дисциплину обслуживания LIFO? FIFO? [1.47%]36. HashMap vs TreeMap [4.04%]37. Как с собой связаны Iterable и foreach? [1.1%]38. Реализации интерфейса Map. Почему интерфейс Map выделен отдельно? [4.41%]39. Какую коллекцию использовать для уникальных отсортированных значений? [0.37%]40. HashTable - что это такое? [0.74%]41. Arrays.asList() and List.of() [1.1%]42. LinkedHashMap [2.94%]43. Структуры данных. Какая сложность в дереве? [1.84%]Исключения [30.88%]1. Расскажите про иерархию исключений [13.24%]2. Что такое Error и Exception? [5.51%]3. Расскажите про обрабатываемые и необрабатываемые исключения [13.24%]4. О чем говорит ключевое слово throws? [1.47%]5. Как создать собственное («пользовательское») исключение? [4.04%]6. Расскажите про механизм обработки исключений в java (Try-catch-finally) [7.35%]7. Возможно ли использование блока try-finally (без catch)? [0.37%]8. Может ли один блок catch отлавливать сразу несколько исключений? [0.74%]9. Всегда ли выполняется блок finally? Существуют ли ситуации, когда блок finally не будет выполнен? [4.04%]10. В каком порядке следует обрабатывать исключения в catch блоках? [1.84%]11. Что такое механизм try-with-resources? [5.15%]12. Ошибка OutOfMemoryError. Поймать утечку памяти и пофиксить [8.46%]13. @SneakyThrows в Lombok [0.74%]14. StackOverflowError vs OutOfMemoryError [1.84%]Дженерики [15.81%]1. Что такое дженерики? Для чего нужны? [7.72%]2. Что такое сырые типы? [0%]3. Что такое вайлдкард [0.74%]4. Расскажите про принцип PECS [4.41%]5. Расскажите про класс Optional [4.78%]6. Что такое стирание типов (Type Erasure) в Java Generics [3.68%]Функциональные интерфейсы [16.54%]1. Что такое функциональный интерфейс? [9.93%]2. Для чего нужна аннотация @FunctionalInterface [1.1%]3. Какие встроенные функциональные интерфейсы вы знаете? [4.78%]4. Что такое ссылка на метод? [0.74%]5. Что такое лямбда выражение? Чем его можно заменить? [8.09%]6. Что делает Интерфейс Function? [0.37%]Stream API [27.94%]1. Что такое Stream API и для чего нужны Stream? [11.4%]2. Почему Stream называют ленивым? [2.57%]3. Какие существуют способы создания Stream? [0.37%]4. Типы методов в Stream API [11.03%]5. Что такое промежуточные методы? Какие промежуточные методы в стримах вы знаете? [4.41%]6. Что такое терминальные методы? Какие терминальные методы в стримах вы знаете? [6.62%]7. Методы в Stream API [0.74%]8. Чем отличаются методы map() и flatMap()? [8.82%]9. Расскажите про класс Collectors и его методы [0.37%]10. Что такое IntStream и DoubleStream? [0.37%]11. В чём разница между parallel и parallelStream? [0.37%]12. Для чего нужны операции Consumer, Function, Supplier? [1.1%]13. Что такое параллельные стримы? [4.41%]14. Разница между findAny() и findFirst() [1.84%]Многопоточность [48.16%]1. Что такое многопоточность? [1.1%]2. Чем процесс отличается от потока? [3.31%]3. Чем Thread отличается от Runnable? Когда использовать Thread, а когда Runnable? [0.37%]4. Что такое монитор? Как реализован в Java? [1.84%]5. Что такое синхронизация? Какие способы синхронизации существуют в Java? [15.81%]6. Что такое FutureTask? [2.57%]7. Что такое CompletableFuture? [5.88%]8. Что такое ExecutorService? [6.99%]9. Как работать с коллекциями в многопоточном программировании? [5.15%]10. SynchronizedCollections. Что это? За счет чего достигается потокобезопасность? [0%]11. Что такое Deadlock [8.82%]12. Что такое Livelock [2.94%]13. Что такое Race condition [6.99%]14. Atomic vs Volatile. Что это и когда использовать? [4.41%]15. Зачем нужны atomic [13.24%]16. Зачем нужны volatile [16.18%]17. Какие бывают состояния у потока? [1.1%]18. Collections.synchronizedMap vs ConcurrentHashMap [2.57%]19. Какими способами можем запустить несколько потоков в Java приложении? Как запустить поток в Java? [8.09%]20. Что за интерфейсы Runnable и Callable? В чем между ними отличия? [3.68%]21. Расскажи про пакет concurrent [1.47%]22. Способы решения задач для многопоточного доступа [0.37%]23. Чем конкурентность отличается от параллелизма? [0.37%]24. Что такое CAS операции? (Compare And Swap) [3.31%]25. Асинхронность vs многопоточность [2.94%]26. Зачем нужны пулы потоков? [0.37%]27. Что значит потокобезопасность? [1.1%]28. Области памяти в многопоточности? [2.21%]29. Executors.newCachedThreadPool() [2.21%]30. Что такое happens-before? [4.04%]31. ForkJoinPool vs FixedThreadPool [0.37%]Базы данных [17.28%]1. Виды БД и для чего их лучше использовать? [2.57%]2. Масштабирование. Как решить нехватку места на сервере? [2.21%]3. Репликация базы данных. Что это такое? [4.41%]4. Что такое шардирование? [7.72%]5. NoSQL vs SQL [4.78%]6. Партиционирование [5.51%]SQL [72.06%]1. Что такое транзакции? [9.56%]2. Расскажите про ACID [12.13%]3. Проблемы параллельных транзакций [8.82%]4. Уровни изолированности (read uncommitted, read committed, repeatable read, serializable) [23.9%]5. Виды JOIN. Как работает каждый JOIN? [13.24%]6. Индексы в SQL. Что это? [20.59%]7. Почему когда много индексов, это плохо? [7.72%]8. Плюсы и минусы индексов [9.56%]9. Какие виды индексов знаешь? [14.34%]10. Как правильно выбрать индекс? [4.04%]11. Нормализация и денормализация. Перечислите формы [8.46%]12. Что такое внешний ключ? [0.37%]13. Чем WHERE отличается от HAVING? Можем ли мы их использовать в одном запросе? [8.46%]14. Чем отличается MySQL от PostgreSQL? [0%]15. Оптимизация запросов. Какие существуют инструменты? [22.06%]16. EXPLAIN vs EXPLAIN ANALYZE [9.93%]17. Инструмент для сбора статистики в PostgreSQL [0.37%]18. Что такое селективность? [2.94%]19. Ключевое слово LATERAL [0.37%]20. Оконные функции. PARTITION BY [2.57%]21. cube, rollup, groupBy [0.74%]22. Хранимые процедуры [2.21%]23. Как работает Serializable? [0.74%]24. View, materialized view. Разница между обычным и материализованным представлением? [4.04%]25. C помощью SQL блокировка строки? - SELECT FOR UPDATE [6.25%]26. UNION vs UNION ALL [1.84%]27. Расскажи про ключевое слово DISTINCT? [1.1%]28. Что такое табличные выражения? [0.37%]29. Для чего используется Database Connection Pool? (Hikari) Исчерпание connection pool [2.21%]30. Блокировки и локи. Оптимистичная и Пессимистичная [17.65%]31. БД. Constraint. Какие существуют? [1.84%]32. Primary Key [2.57%]33. Foreign Key [3.68%]34. DELETE vs TRUNCATE [1.1%]NoSQL [4.04%]1. NoSQL типы БД [1.47%]2. Для чего используется Redis? [2.94%]3. Что такое Кэш? [0.74%]Миграции [4.41%]1. Liquibase. Что это и для чего? [3.31%]2. Какие записи создаёт liquibase во время миграции? [0.74%]3. Зачем нужны инструменты миграции? [1.1%]ORM [43.01%]1. Что такое Hibernate, JPA, JDBC, ORM? [5.51%]2. Плюсы и минусы ORM [3.31%]3. Как создать Entity и что это такое? [2.21%]4. Может ли Entity наследоваться от не-Entity классов? [0%]5. Может ли Entity наследоваться от других Entity классов? [0%]6. Почему мы не можем использовать final классы в качестве Entity? [0.37%]7. Что такое Proxy и для чего используется? [9.93%]8. FetchType [2.57%]9. Жизненный цикл сущности [5.15%]10. Кэширование [6.62%]11. HQL и JPQL [0.74%]12. EntityManager + EntityManagerFactory / SessionFactory + session [1.84%]13. Проблема N + 1. Способы решения проблемы [20.59%]14. Что такое Entity Graph? [4.04%]15. Statement, Prepared statement, Callable statement [2.21%]16. Связи между таблицами в ORM [3.31%]17. LazyInitializationException [4.78%]18. Что такое SQL-инъекция? [1.1%]19. Проблемы JOIN FETCH [0.74%]20. Логи в Hibernate [0.37%]21. Аннотация @Query, что это такое? [1.84%]22. Как Hibernate генерирует SQL запросы? [0.37%]23. Hibernate. Что хранится в Persistence Context? Сколько времени объект хранится в Persistence Context? [2.57%]24. Hibernate и Lombok [1.1%]25. Как JPA делает запросы? [0.74%]26. Стратегии наследования в Hibernate [2.94%]Spring [79.78%]1. Зачем мы используем Spring? Почему его так любят? [11.4%]2. Inversion of Control [11.03%]3. Dependency Injection [12.13%]4. Какие способы внедрения зависимостей знаешь? [14.71%]5. Почему лучше использовать конструктор? [12.13%]6. @Autowired [4.41%]7. @Qualifier vs @Primary [12.87%]8. Что такое Bean? [10.66%]9. Скоуп бинов. Web скоуп [26.1%]10. Как обеспечить, чтобы при внедрении бина со скоупом prototype в singleton-бин каждый вызов получал новый экземпляр? [5.88%]11. Жизненный цикл Bean. Вопросы связанные с классами, входящими в жизненный цикл бина [19.85%]12. @ComponentScan [3.31%]13. @Conditional в Spring [3.31%]14. @Service, @Repository, @Component [14.71%]15. @Controller и @RestController [8.46%]16. @ResponseBody vs ResponseEntity [0.37%]17. Spring MVC. Что это? Какие проблемы решает? [1.1%]18. Парадигма AOP [6.62%]19. Циклическая зависимость [8.09%]20. Spring Boot [7.35%]21. Spring Boot vs Spring [10.66%]22. Spring JDBC [0.74%]23. Spring Data JPA [4.41%]24. Блокировка по умолчанию в Spring [0.37%]25. @Transactional. Как работает? [27.57%]26. Какие есть атрибуты у @Transactional? [4.41%]27. Атрибут propagation у @Transactional [9.19%]28. @Transaction Что будет если вызвать метод из метода в одном классе при различных сценариях [14.71%]29. Как гарантировать корректное обновление и сохранение изменений в сущностях, полученных в методе с @Transactional [1.47%]30. @Transactional и Исключения [3.31%]31. @Async [2.21%]32. Starter в Spring. Плюсы и минусы [5.51%]33. Spring Criteria API [3.31%]34. @Scheduled [3.68%]35. Понятие Controller и Servlet в Java. Это одно и то же? Если разное, в чем отличия? [1.1%]36. Что такое объект Filter? В какой момент вызывается? [0.74%]37. Что такое ApplicationContext? Как работает под капотом [5.15%]38. Зачем нужны аннотации @RequestParam и @PathVariable? [0.74%]39. @ConfigurationProperties? ConfigurationProperties vs Value [1.1%]40. @Value. Что это? [1.1%]41. Как работает DispatcherServlet? [2.21%]42. Варианты обработки Exceptions в Spring [1.1%]43. @Configuration. Является Configuration компонентом? Какую доп логику Configuration реализует? [1.47%]44. @PostConstruct [2.94%]45. Dependency management в Spring boot [0.37%]46. Spring Security, как хранить пароль пользователя? [0.74%]47. Spring Profiles как с ними работать? [1.84%]48. Виды proxy в Spring [5.51%]49. @Lookup [1.84%]50. Как работает BeanPostProcessor. Почему есть before и after initialization [2.57%]51. @Lazy [4.04%]52. @ControllerAdvice [4.04%]53. Как устроен Spring Security [2.57%]Паттерны проектирования [19.85%]1. GOF паттерны [11.4%]2. Что такое паттерн? [0%]3. Плюсы и минусы использования паттернов [0%]4. Какие существуют группы паттернов? [3.31%]5. Какие паттерны в какую группу входят? [0.37%]6. Adapter vs Decorator [0%]7. Паттерн MVC [1.1%]8. Паттерн Command [0.74%]9. Паттерн Chain of responsibility [0.74%]10. Как реализуется паттер Abstract Factory? [1.84%]11. Какие паттерны проектирования используются в Spring [2.57%]12. Плюсы и минусы паттерна Singleton? [5.15%]13. Паттерн Builder [2.21%]WEB [22.43%]1. REST [7.35%]2. RESTful и RESTless [2.21%]3. REST vs SOAP [1.1%]4. В каких ситуациях допустимо использование RESTless [0%]5. REST vs RPC. Как выбрать что лучше подходит? [2.94%]6. Назовите 6 принципов REST API [1.1%]7. Идемпотентный метод [2.57%]8. Основные HTTP методы [7.35%]9. Статусы ответов [2.57%]10. GET vs POST [5.15%]11. Разница HTTP и HTTPs [1.84%]12. Из чего состоит HTTP запрос [2.21%]13. Какие методы авторизации существуют для HTTP протокола? [0.37%]14. Из чего состоит JSON Web Token? [1.1%]15. Какие протоколы уровня приложений? [0.37%]16. Что такое HTTP? [0.74%]17. За что отвечают Cookie/куки? [0.74%]18. Отличия POST, PUT, PATCH [3.31%]Микросервисы [23.9%]1. Монолит vs Микросервис [4.78%]2. Плюсы и минусы микросервисов [4.78%]3. Паттерн Saga в микросервисной архитектуре [6.25%]4. CAP теорема [2.21%]5. Паттерн Circuit Breaker [3.68%]6. Паттерн API Gateway [2.21%]7. HTTP vs Kafka. Какой способ общения между микросервисами лучше и почему? [1.47%]8. Шаблоны проектирования для микросервисов (паттерны) [6.25%]9. Что такое Transactional Outbox [5.51%]Брокеры сообщений [44.49%]1. Плюсы и минусы брокеров сообщений [2.57%]2. Разница между Kafka и RabbitMQ [7.35%]3. Что такое топик в Kafka? [6.62%]4. Что такое Producer и что такое Consumer? [1.47%]5. Что такое partition в Kafka? [10.29%]6. Распределение сообщений. Как сообщения распределяются по партициям? [11.4%]7. Гарантии доставки в Kafka [12.87%]8. Какие существуют паттерны работы с очередями? [0.37%]9. Основные компоненты Kafka? [12.13%]10. Kafka. Consumer Group [9.19%]11. Из чего состоит Kafka кластер? [0.74%]12. Брокеры сообщений vs Rest [4.41%]13. Pull и push модели, в чём разница? [0.74%]14. Как гарантировать в Kafka идемпотентность, чтобы не было задвоений и потерь сообщений? [4.41%]15. Как в Kafka гарантируется последовательность сообщений? [2.94%]16. Что сделать, чтобы сообщения попадали в одну партицию? [0.37%]17. Как работает Round Robin? [0.37%]18. Acknowledgment в Kafka [0.37%]19. Смещение (offset) в Kafka [2.94%]20. Повторное чтение данных из Kafka [0.74%]21. DLQ topic? [1.1%]Тестирование [11.03%]1. На чем пишутся тесты? [1.1%]2. Mock vs spy [4.41%]3. Параметризованные тесты [1.1%]4. Unit тесты. Что это и зачем? [0.74%]5. Unit тесты vs интеграционные тесты [1.47%]6. Mock. Как работает? [4.41%]7. Spy. Как работает? [0.74%]8. Каким образом проверяются результаты тестов? [0.37%]9. Основные аннотации в тестировании [0.74%]Деплой [9.93%]1. CI/CD [2.57%]2. Как работает Docker. Из чего состоит докер образ? [3.31%]3. Что такое слой? Как мы можем создать новый слой? [0.37%]4. Docker compose [2.94%]5. ARG, ENV. В чем отличия? [0.37%]6. Docker cmd vs entrypoint [0.74%]7. Отличия контейнеризации от виртулизации [4.78%]8. Поддержка сервиса в продакшене, мониторинг его работы. Общие подходы? [0.37%]Другое [20.22%]1. Инструменты для отладки приложения, течет память, все замирает - Visual VM, JMap, профилировщики [2.21%]2. Определение сложности алгоритма [2.94%]3. Для чего нужно O большое в алгоритмах? (Что такое сложность в алгоритме) [4.41%]4. Какой подход к неймингу методов позволяет ясно и однозначно отражать их функциональность, например, для методов, которые выполняют поиск с сортировкой, очистку кэша или расчёт с сохранением данных и возвратом статуса? [0.74%]5. Как выявлять и устранять узкие места производительности в REST-сервисах и микросервисных архитектурах, когда рост нагрузки (например, увеличение трафика или обращений к БД) приводит к значительно более долгой обработке запросов, чем ожидается, и какие стратегии оптимизации (в том числе архитектурные изменения и масштабирование) могут помочь достичь требуемых временных рамок отклика? [1.47%]6. Обычное программирование vs реактивщина [2.57%]7. Для чего нужен Reflection? [4.04%]8. Что такое идемпотентность? [4.04%]