Технические вопросы #ООП [10.31%]1. Что такое ООП? [2.29%]2. Плюсы и минусы ООП [0%]3. Принципы ООП (наследование, инкапсуляция, полиморфизм, абстракция) [9.92%]4. Класс, объект, интерфейс [0.38%]5. Ассоциация, агрегация, композиция [0.76%]6. Статическое и динамическое связывание [1.15%]7. Является – «is a», имеет – «has a» [0.38%]SOLID [19.47%]1. Что такое SOLID (каждая буква)? [19.08%]2. Какие принципы можешь назвать? [1.15%]3. Когда мы можем нарушать принципы SOLID? [1.15%]Java Core [67.56%]1. Расскажи мне про контракт и свойства Equals & Hashcode [20.23%]2. Что такое коллизия? [3.82%]3. Какие типы ссылок существуют в Java? [3.82%]4. Какой класс называют Immutable? [11.07%]5. Основная идея языка [0%]6. За счет чего обеспечена кроссплатформенность? [0.38%]7. Плюсы и минусы Java? [0%]8. JVM, JRE, JDK, JIT [2.29%]9. Что такое байт-код? [0.76%]10. Что такое сборщик мусора (garbage collector)? [8.02%]11. Как работает GC? [14.12%]12. Какие виды GC знаешь? [6.87%]13. Области памяти Java. Stack и heap. Что это такое? [16.79%]14. Типы данных в Java [1.15%]15. Что такое класс-обертка? [3.05%]16. Автоупаковка и автораспаковка [0.38%]17. Строки/String в Java? Из чего состоит? Нюансы [6.87%]18. Что такое пул строк/String pool? [9.16%]19. Почему не рекомендуется изменять строки в цикле? [0.38%]20. Разница между String, StringBuffer, StringBuilder [4.96%]21. Каким образом переменные передаются в методы — по значению или по ссылке? [2.29%]22. Что такое enum? [0.76%]23. Что такое конструктор? [1.53%]24. Какие есть модификаторы доступа? Какие применимы к классам? [3.05%]25. Что означает static? [5.34%]26. Можно ли сузить уровень доступа или тип возвращаемого значения при переопределении метода? [0.38%]27. Что можно изменить в сигнатуре метода при переопределении? Можно ли менять модификаторы (throws и т. п.)? [0.38%]28. Что означает модификатор final? К чему он может быть применим? [8.02%]29. Что такое абстрактные классы? [2.67%]30. Что такое интерфейсы? [2.29%]31. Отличия интерфейса от абстрактных классов? [14.12%]32. Каков порядок вызова конструкторов и блоков инициализации с учетом иерархии классов? [1.91%]33. Зачем нужны и какие бывают блоки инициализации? [0.38%]34. Для чего в Java используются статические блоки инициализации? [0.38%]35. Класс Object и его методы? [4.58%]36. Что такое сериализация и для чего она нужна? [1.15%]37. Разница между версиями Java [0.38%]38. Может ли абстрактный класс быть final? [0.38%]39. Integer pool [1.53%]40. Какие виды загрузчиков классов ты знаешь? [0.38%]41. Record-ы с Java 17. Для чего и зачем? [1.53%]42. Что такое Анонимный класс [1.53%]43. Расскажи что делает JIT компилятор [1.91%]44. Расскажи про прогрев JVM [0.38%]45. break vs continue в цикле [0.76%]46. Что такое аннотация? Зачем нужна? Как создать свою аннотацию? [3.82%]47. Переопределение и перегрузка методов [4.58%]48. ClassLoader в Java [3.44%]49. В чем разница сравнений по equals и "=="? [2.67%]Коллекции [57.25%]1. Расскажите как выглядит иерархия коллекций [21.76%]2. Что такое ArrayList? [5.73%]3. ArrayList. Какая размерность массива по умолчанию? [0.38%]4. ArrayList. Что происходит под капотом при добавлении/удалении элемента в начало/середину/конец списка? [5.34%]5. ArrayList - сложность операций [4.58%]6. Что такое LinkedList? [2.67%]7. LinkedList. Что происходит под капотом при добавлении/удалении элемента в начало/середину/конец списка? [3.82%]8. LinkedList - сложность операций [3.44%]9. ArrayList vs LinkedList [17.56%]10. Какая скорость вставки в ArrayList и LinkedList [3.82%]11. Что такое TreeMap? [3.05%]12. TreeMap - сложность операций [1.91%]13. Внутреннее устройство TreeMap [3.44%]14. Что такое HashMap? [9.92%]15. Внутреннее устройство HashMap [17.56%]16. Что такое бакет? Внутреннее устройство бакета [6.49%]17. HashMap - сложность операций [11.83%]18. Процесс добавления объекта в HashMap [12.6%]19. Будет ли работать HashMap, если все добавляемые ключи будут иметь одинаковый hashCode()? [14.5%]20. Ключи в HashMap [6.87%]21. Могу положить в HashMap или TreeMap элемент с ключом null? [2.29%]22. Что такое HashSet? [4.2%]23. Как HashSet связан с HashMap? [0.76%]24. Внутреннее устройство HashSet [2.67%]25. HashSet - сложность операций [1.53%]26. Процесс добавления объекта в HashSet? [1.15%]27. Будет ли работать HashSet, если все добавляемые элементы будут иметь одинаковый hashCode()? [0.38%]28. Что такое TreeSet? Внутреннее устройство [3.44%]29. Что такое Queue? [0.76%]30. Queue - сложность операций [0%]31. Назовите главные реализации Queue [0.38%]32. Что такое Deque? [0.38%]33. Назовите главные реализации Deque [0%]34. Deque - сложность операций [0%]35. Какая коллекция реализует дисциплину обслуживания LIFO? FIFO? [1.53%]36. HashMap vs TreeMap [3.82%]37. Как с собой связаны Iterable и foreach? [1.15%]38. Реализации интерфейса Map. Почему интерфейс Map выделен отдельно? [4.2%]39. Какую коллекцию использовать для уникальных отсортированных значений? [0.38%]40. HashTable - что это такое? [0.76%]41. Arrays.asList() and List.of() [1.15%]42. LinkedHashMap [3.05%]43. Структуры данных. Какая сложность в дереве? [1.91%]Исключения [30.92%]1. Расскажите про иерархию исключений [13.36%]2. Что такое Error и Exception? [5.34%]3. Расскажите про обрабатываемые и необрабатываемые исключения [13.36%]4. О чем говорит ключевое слово throws? [1.53%]5. Как создать собственное («пользовательское») исключение? [4.2%]6. Расскажите про механизм обработки исключений в java (Try-catch-finally) [7.63%]7. Возможно ли использование блока try-finally (без catch)? [0.38%]8. Может ли один блок catch отлавливать сразу несколько исключений? [0.76%]9. Всегда ли выполняется блок finally? Существуют ли ситуации, когда блок finally не будет выполнен? [3.82%]10. В каком порядке следует обрабатывать исключения в catch блоках? [1.91%]11. Что такое механизм try-with-resources? [4.96%]12. Ошибка OutOfMemoryError. Поймать утечку памяти и пофиксить [8.4%]13. @SneakyThrows в Lombok [0.76%]14. StackOverflowError vs OutOfMemoryError [1.91%]Дженерики [16.03%]1. Что такое дженерики? Для чего нужны? [7.63%]2. Что такое сырые типы? [0%]3. Что такое вайлдкард [0.76%]4. Расскажите про принцип PECS [4.58%]5. Расскажите про класс Optional [4.96%]6. Как JVM работает с Generics [3.44%]Функциональные интерфейсы [16.03%]1. Что такое функциональный интерфейс? [9.16%]2. Для чего нужна аннотация @FunctionalInterface [1.15%]3. Какие встроенные функциональные интерфейсы вы знаете? [4.96%]4. Что такое ссылка на метод? [0.76%]5. Что такое лямбда выражение? Чем его можно заменить? [7.63%]6. Что делает Интерфейс Function? [0.38%]Stream API [27.86%]1. Что такое Stream API и для чего нужны Stream? [11.07%]2. Почему Stream называют ленивым? [2.67%]3. Какие существуют способы создания Stream? [0.38%]4. Типы методов в Stream API [10.69%]5. Что такое промежуточные методы? Какие промежуточные методы в стримах вы знаете? [4.58%]6. Что такое терминальные методы? Какие терминальные методы в стримах вы знаете? [6.87%]7. Методы в Stream API [0.76%]8. Чем отличаются методы map() и flatMap()? [8.78%]9. Расскажите про класс Collectors и его методы [0.38%]10. Что такое IntStream и DoubleStream? [0.38%]11. В чём разница между parallel и parallelStream? [0.38%]12. Для чего нужны операции Consumer, Function, Supplier? [1.15%]13. Что такое параллельные стримы? [4.58%]14. Разница между findAny() и findFirst() [1.91%]Многопоточность [48.09%]1. Что такое многопоточность? [1.15%]2. Чем процесс отличается от потока? [2.67%]3. Чем Thread отличается от Runnable? Когда использовать Thread, а когда Runnable? [0.38%]4. Что такое монитор? Как реализован в Java? [1.91%]5. Что такое синхронизация? Какие способы синхронизации существуют в Java? [16.03%]6. Что такое FutureTask? [2.29%]7. Что такое CompletableFuture? [5.73%]8. Что такое ExecutorService? [6.49%]9. Как работать с коллекциями в многопоточном программировании? [4.96%]10. SynchronizedCollections. Что это? За счет чего достигается потокобезопасность? [0%]11. Что такое Deadlock [8.78%]12. Что такое Livelock [3.05%]13. Что такое Race condition [7.25%]14. Atomic vs Volatile. Что это и когда использовать? [4.2%]15. Зачем нужны atomic [13.36%]16. Зачем нужны volatile [16.03%]17. Какие бывают состояния у потока? [1.15%]18. Collections.synchronizedMap vs ConcurrentHashMap [2.67%]19. Какими способами можем запустить несколько потоков в Java приложении? Как запустить поток в Java? [8.02%]20. Что за интерфейсы Runnable и Callable? В чем между ними отличия? [3.44%]21. Расскажи про пакет concurrent [1.15%]22. Способы решения задач для многопоточного доступа [0.38%]23. Чем конкурентность отличается от параллелизма? [0.38%]24. Что такое CAS операции? (Compare And Swap) [3.44%]25. Асинхронность vs многопоточность [3.05%]26. Зачем нужны пулы потоков? [0.38%]27. Что значит потокобезопасность? [1.15%]28. Области памяти в многопоточности? [2.29%]29. Executors.newCachedThreadPool() [1.91%]30. Что такое happens-before? [4.2%]31. ForkJoinPool vs FixedThreadPool [0.38%]Базы данных [17.18%]1. Виды БД и для чего их лучше использовать? [2.67%]2. Масштабирование. Как решить нехватку места на сервере? [2.29%]3. Репликация базы данных. Что это такое? [4.58%]4. Что такое шардирование? [7.63%]5. NoSQL vs SQL [4.58%]6. Партиционирование [5.34%]SQL [72.52%]1. Что такое транзакции? [8.4%]2. Расскажите про ACID [10.69%]3. Проблемы параллельных транзакций [8.78%]4. Уровни изолированности (read uncommitted, read committed, repeatable read, serializable) [23.28%]5. Виды JOIN. Как работает каждый JOIN? [12.98%]6. Индексы в SQL. Что это? [20.99%]7. Почему когда много индексов, это плохо? [7.63%]8. Плюсы и минусы индексов [8.78%]9. Какие виды индексов знаешь? [14.89%]10. Как правильно выбрать индекс? [3.82%]11. Нормализация и денормализация. Перечислите формы [8.4%]12. Что такое внешний ключ? [0.38%]13. Чем WHERE отличается от HAVING? Можем ли мы их использовать в одном запросе? [8.02%]14. Чем отличается MySQL от PostgreSQL? [0%]15. Оптимизация запросов. Какие существуют инструменты? [22.52%]16. EXPLAIN vs EXPLAIN ANALYZE [10.31%]17. Инструмент для сбора статистики в PostgreSQL [0.38%]18. Что такое селективность? [3.05%]19. Ключевое слово LATERAL [0.38%]20. Оконные функции. PARTITION BY [2.29%]21. cube, rollup, groupBy [0.76%]22. Хранимые процедуры [2.29%]23. Как работает Serializable? [0.76%]24. View, materialized view. Разница между обычным и материализованным представлением? [4.2%]25. C помощью SQL блокировка строки? - SELECT FOR UPDATE [6.11%]26. UNION vs UNION ALL [1.91%]27. Расскажи про ключевое слово DISTINCT? [1.15%]28. Что такое табличные выражения? [0.38%]29. Для чего используется Database Connection Pool? (Hikari) Исчерпание connection pool [2.29%]30. Блокировки и локи. Оптимистичная и Пессимистичная [17.56%]31. БД. Constraint. Какие существуют? [1.91%]32. Primary Key [2.29%]33. Foreign Key [3.82%]34. DELETE vs TRUNCATE [1.15%]NoSQL [3.82%]1. NoSQL типы БД [1.15%]2. Для чего используется Redis? [3.05%]3. Что такое Кэш? [0.76%]Миграции [4.58%]1. Liquibase. Что это и для чего? [3.44%]2. Какие записи создаёт liquibase во время миграции? [0.76%]3. Зачем нужны инструменты миграции? [1.15%]ORM [43.13%]1. Что такое Hibernate, JPA, JDBC, ORM? [5.34%]2. Плюсы и минусы ORM [3.05%]3. Как создать Entity и что это такое? [2.29%]4. Может ли Entity наследоваться от не-Entity классов? [0%]5. Может ли Entity наследоваться от других Entity классов? [0%]6. Почему мы не можем использовать final классы в качестве Entity? [0.38%]7. Что такое Proxy и для чего используется? [9.92%]8. FetchType [2.67%]9. Жизненный цикл сущности [5.34%]10. Кэширование [6.87%]11. HQL и JPQL [0.76%]12. EntityManager + EntityManagerFactory / SessionFactory + session [1.53%]13. Проблема N + 1. Способы решения проблемы [20.23%]14. Что такое Entity Graph? [4.2%]15. Statement, Prepared statement, Callable statement [2.29%]16. Связи между таблицами в ORM [3.44%]17. LazyInitializationException [4.96%]18. Что такое SQL-инъекция? [1.15%]19. Проблемы JOIN FETCH [0.76%]20. Логи в Hibernate [0.38%]21. Аннотация @Query, что это такое? [1.91%]22. Как Hibernate генерирует SQL запросы? [0.38%]23. Hibernate. Что хранится в Persistence Context? Сколько времени объект хранится в Persistence Context? [2.67%]24. Hibernate и Lombok [1.15%]25. Как JPA делает запросы? [0.76%]26. Стратегии наследования в Hibernate [3.05%]Spring [80.15%]1. Зачем мы используем Spring? Почему его так любят? [11.45%]2. Inversion of Control [10.69%]3. Dependency Injection [12.21%]4. Какие способы внедрения зависимостей знаешь? [14.5%]5. Почему лучше использовать конструктор? [12.21%]6. @Autowired [4.58%]7. @Qualifier vs @Primary [12.98%]8. Что такое Bean? [10.69%]9. Скоуп бинов. Web скоуп [25.95%]10. Как обеспечить, чтобы при внедрении бина со скоупом prototype в singleton-бин каждый вызов получал новый экземпляр? [5.73%]11. Жизненный цикл Bean. Вопросы связанные с классами, входящими в жизненный цикл бина [20.23%]12. @ComponentScan [3.05%]13. @Conditional в Spring [3.44%]14. @Service, @Repository, @Component [14.5%]15. @Controller и @RestController [8.4%]16. @ResponseBody vs ResponseEntity [0.38%]17. Spring MVC. Что это? Какие проблемы решает? [1.15%]18. Парадигма AOP [6.87%]19. Циклическая зависимость [8.02%]20. Spring Boot [6.87%]21. Spring Boot vs Spring [10.31%]22. Spring JDBC [0.76%]23. Spring Data JPA [4.2%]24. Блокировка по умолчанию в Spring [0.38%]25. @Transactional. Как работает? [28.24%]26. Какие есть атрибуты у @Transactional? [4.58%]27. Атрибут propagation у @Transactional [9.16%]28. @Transaction Что будет если вызвать метод из метода в одном классе при различных сценариях [14.5%]29. Как гарантировать корректное обновление и сохранение изменений в сущностях, полученных в методе с @Transactional [1.53%]30. @Transactional и Исключения [3.44%]31. @Async [2.29%]32. Starter в Spring. Плюсы и минусы [4.58%]33. Spring Criteria API [3.44%]34. @Scheduled [3.82%]35. Понятие Controller и Servlet в Java. Это одно и то же? Если разное, в чем отличия? [1.15%]36. Что такое объект Filter? В какой момент вызывается? [0.76%]37. Что такое ApplicationContext? Как работает под капотом [4.96%]38. Зачем нужны аннотации @RequestParam и @PathVariable? [0.76%]39. @ConfigurationProperties? ConfigurationProperties vs Value [1.15%]40. @Value. Что это? [1.15%]41. Как работает DispatcherServlet? [2.29%]42. Варианты обработки Exceptions в Spring [1.15%]43. @Configuration. Является Configuration компонентом? Какую доп логику Configuration реализует? [1.53%]44. @PostConstruct [3.05%]45. Dependency management в Spring boot [0.38%]46. Spring Security, как хранить пароль пользователя? [0.76%]47. Spring Profiles как с ними работать? [1.91%]48. Виды proxy в Spring [5.73%]49. @Lookup [1.91%]50. Как работает BeanPostProcessor. Почему есть before и after initialization [2.67%]51. @Lazy [4.2%]52. @ControllerAdvice [4.2%]53. Как устроен Spring Security [2.29%]Паттерны проектирования [20.23%]1. GOF паттерны [11.45%]2. Что такое паттерн? [0%]3. Плюсы и минусы использования паттернов [0%]4. Какие существуют группы паттернов? [3.05%]5. Какие паттерны в какую группу входят? [0.38%]6. Adapter vs Decorator [0%]7. Паттерн MVC [1.15%]8. Паттерн Command [0.76%]9. Паттерн Chain of responsibility [0.76%]10. Как реализуется паттер Abstract Factory? [1.91%]11. Какие паттерны проектирования используются в Spring [2.67%]12. Плюсы и минусы паттерна Singleton? [5.34%]13. Паттерн Builder [2.29%]WEB [22.52%]1. REST [7.25%]2. RESTful и RESTless [2.29%]3. REST vs SOAP [1.15%]4. В каких ситуациях допустимо использование RESTless [0%]5. REST vs RPC. Как выбрать что лучше подходит? [3.05%]6. Назовите 6 принципов REST API [0.76%]7. Идемпотентный метод [2.67%]8. Основные HTTP методы [7.25%]9. Статусы ответов [2.67%]10. GET vs POST [4.96%]11. Разница HTTP и HTTPs [1.91%]12. Из чего состоит HTTP запрос [2.29%]13. Какие методы авторизации существуют для HTTP протокола? [0.38%]14. Из чего состоит JSON Web Token? [1.15%]15. Какие протоколы уровня приложений? [0.38%]16. Что такое HTTP? [0.76%]17. За что отвечают Cookie/куки? [0.76%]18. Отличия POST, PUT, PATCH [3.44%]Микросервисы [22.52%]1. Монолит vs Микросервис [4.96%]2. Плюсы и минусы микросервисов [4.96%]3. Паттерн Saga в микросервисной архитектуре [6.11%]4. CAP теорема [1.91%]5. Паттерн Circuit Breaker [3.82%]6. Паттерн API Gateway [2.29%]7. HTTP vs Kafka. Какой способ общения между микросервисами лучше и почему? [1.53%]8. Шаблоны проектирования для микросервисов (паттерны) [6.11%]9. Что такое Transactional Outbox [4.58%]Брокеры сообщений [44.27%]1. Плюсы и минусы брокеров сообщений [2.67%]2. Разница между Kafka и RabbitMQ [6.87%]3. Что такое топик в Kafka? [6.87%]4. Что такое Producer и что такое Consumer? [1.15%]5. Что такое partition в Kafka? [9.92%]6. Распределение сообщений. Как сообщения распределяются по партициям? [11.45%]7. Гарантии доставки в Kafka [11.83%]8. Какие существуют паттерны работы с очередями? [0.38%]9. Основные компоненты Kafka? [12.21%]10. Kafka. Consumer Group [9.54%]11. Из чего состоит Kafka кластер? [0.76%]12. Брокеры сообщений vs Rest [4.2%]13. Pull и push модели, в чём разница? [0.76%]14. Как гарантировать в Kafka идемпотентность, чтобы не было задвоений и потерь сообщений? [4.58%]15. Как в Kafka гарантируется последовательность сообщений? [2.67%]16. Что сделать, чтобы сообщения попадали в одну партицию? [0.38%]17. Как работает Round Robin? [0.38%]18. Acknowledgment в Kafka [0.38%]19. Смещение (offset) в Kafka [3.05%]20. Повторное чтение данных из Kafka [0.76%]21. DLQ topic? [0.76%]Тестирование [11.07%]1. На чем пишутся тесты? [1.15%]2. Mock vs spy [4.58%]3. Параметризованные тесты [1.15%]4. Unit тесты. Что это и зачем? [0.76%]5. Unit тесты vs интеграционные тесты [1.53%]6. Mock. Как работает? [4.2%]7. Spy. Как работает? [0.76%]8. Каким образом проверяются результаты тестов? [0.38%]9. Основные аннотации в тестировании [0.76%]Деплой [10.31%]1. CI/CD [2.67%]2. Как работает Docker. Из чего состоит докер образ? [3.44%]3. Что такое слой? Как мы можем создать новый слой? [0.38%]4. Docker compose [3.05%]5. ARG, ENV. В чем отличия? [0.38%]6. Docker cmd vs entrypoint [0.76%]7. Отличия контейнеризации от виртулизации [4.96%]8. Поддержка сервиса в продакшене, мониторинг его работы. Общие подходы? [0.38%]Другое [20.23%]1. Инструменты для отладки приложения, течет память, все замирает - Visual VM, JMap, профилировщики [2.29%]2. Определение сложности алгоритма [3.05%]3. Для чего нужно O большое в алгоритмах? (Что такое сложность в алгоритме) [4.58%]4. Какой подход к неймингу методов позволяет ясно и однозначно отражать их функциональность, например, для методов, которые выполняют поиск с сортировкой, очистку кэша или расчёт с сохранением данных и возвратом статуса? [0.76%]5. Как выявлять и устранять узкие места производительности в REST-сервисах и микросервисных архитектурах, когда рост нагрузки (например, увеличение трафика или обращений к БД) приводит к значительно более долгой обработке запросов, чем ожидается, и какие стратегии оптимизации (в том числе архитектурные изменения и масштабирование) могут помочь достичь требуемых временных рамок отклика? [1.53%]6. Обычное программирование vs реактивщина [2.29%]7. Для чего нужен Reflection? [4.2%]8. Что такое идемпотентность? [3.82%]