Технические вопросы #ООП [12%] #1. Что такое ООП? [4%] #2. Плюсы и минусы ООП [0%] #3. Принципы ООП (наследование, инкапсуляция, полиморфизм, абстракция) [11%] #4. Класс, объект, интерфейс [0%] #5. Ассоциация, агрегация, композиция [1%] #6. Статическое и динамическое связывание [2%] #7. Является – «is a», имеет – «has a» [1%] #SOLID [18%] #1. Что такое SOLID(каждая буква)? [18%] #2. Какие принципы можешь назвать? [1%] #3. Когда мы можем нарушать принципы SOLID? [2%] #Java Core [65%] #1. Расскажи мне про контракт и свойства Equals & Hashcode [18%] #2. Что такое коллизия? [5%] #3. Какие типы ссылок существуют в Java? [4%] #4. Какой класс называют Immutable? [8%] #5. Основная идея языка [0%] #6. За счет чего обеспечена кроссплатформенность? [1%] #7. Плюсы и минусы Java? [0%] #8. JVM, JRE, JDK, JIT [6%] #9. Что такое байт-код? [1%] #10. Что такое сборщик мусора (garbage collector)? [8%] #11. Области памяти Java. Stack и heap. Что это такое? [17%] #12. Типы данных в Java [2%] #13. Что такое класс-обертка? [2%] #14. Автоупаковка и автораспаковка [1%] #15. Строки/String в Java? Из чего состоит? Нюансы [6%] #16. Что такое пул строк/String pool? [7%] #17. Почему не рекомендуется изменять строки в цикле? [1%] #18. Разница между String, StringBuffer, StringBuilder [1%] #19. Каким образом переменные передаются в методы — по значению или по ссылке? [1%] #20. Что такое enum? [1%] #21. Что такое конструктор? [0%] #22. Какие есть модификаторы доступа? Какие применимы к классам? [1%] #23. Что означает static? [4%] #24. Можно ли сузить уровень доступа или тип возвращаемого значения при переопределении метода? [0%] #25. Что можно изменить в сигнатуре метода при переопределении? Можно ли менять модификаторы (throws и т. п.)? [0%] #26. Что означает модификатор final? К чему он может быть применим? [6%] #27. Что такое абстрактные классы? [5%] #28. Что такое интерфейсы? [4%] #29. Отличия интерфейса от абстрактных классов? [16%] #30. Каков порядок вызова конструкторов и блоков инициализации с учетом иерархии классов? [2%] #31. Зачем нужны и какие бывают блоки инициализации? [1%] #32. Для чего в Java используются статические блоки инициализации? [0%] #33. Класс Object и его методы? [4%] #34. Что такое сериализация и для чего она нужна? [1%] #35. Разница между версиями Java [1%] #36. Может ли абстрактный класс быть final? #37. Integer pool [1%] #38. Какие виды загрузчиков классов ты знаешь? [1%] #39. Record-ы с Java 17. Для чего и зачем? [2%] #40. Что такое Анонимный класс [2%] #41. Расскажи что делает JIT компилятор [2%] #42. Расскажи про прогрев JVM [1%] #43. break vs continue в цикле [1%] #44. Что такое аннотация? Зачем нужна? Как создать свою аннотацию? [4%] #Коллекции [63%] #1. Расскажите как выглядит иерархия коллекций [24%] #2. Что такое ArrayList? [10%] #3. ArrayList. Какая размерность массива по умолчанию? [0%] #4. ArrayList. Что происходит под капотом при добавлении/удалении элемента в начало/середину/конец списка? [6%] #5. ArrayList - сложность операций [5%] #6. Что такое LinkedList? [4%] #7. LinkedList. Что происходит под капотом при добавлении/удалении элемента в начало/середину/конец списка? [4%] #8. LinkedList - сложность операций [6%] #9. ArrayList vs LinkedList [19%] #10. Что такое TreeMap? [2%] #11. TreeMap - сложность операций [0%] #12. Внутреннее устройство TreeMap [1%] #13. Что такое HashMap? [14%] #14. Внутреннее устройство HashMap [12%] #15. HashMap - сложность операций [14%] #16. Процесс добавления объекта в HashMap [17%] #17. Будет ли работать HashMap, если все добавляемые ключи будут иметь одинаковый hashCode()? [19%] #18. Ключи в HashMap [7%] #19. Что такое HashSet? [2%] #20. Как HashSet связан с HashMap? [1%] #21. Внутреннее устройство HashSet [1%] #22. HashSet - сложность операций [0%] #23. Процесс добавления объекта в HashSet? [0%] #24. Будет ли работать HashSet, если все добавляемые элементы будут иметь одинаковый hashCode()? [0%] #25. Что такое Queue? [1%] #26. Queue - сложность операций [0%] #27. Назовите главные реализации Queue [1%] #28. Что такое Dequeue? [1%] #29. Назовите главные реализации Dequeue [0%] #30. Dequeue - сложность операций [0%] #31. Какая коллекция реализует дисциплину обслуживания LIFO? FIFO? [0%] #32. HashMap vs TreeMap [2%] #33. Как с собой связаны Iterable и foreach? [1%] #34. Реализации интерфейса Map. Почему интерфейс Map выделен отдельно? [7%] #35. Какую коллекцию использовать для уникальных отсортированных значений? [1%] #36. HashTable - что это такое? [1%] #37. Arrays.asList() and List.of() [1%] #38. Структуры данных. Какая сложность в дереве? [5%] #Исключения [33%] #1. Расскажите про иерархию исключений [18%] #2. Что такое Error и Exception? [6%] #3. Расскажите про обрабатываемые и необрабатываемые исключения [12%] #4. О чем говорит ключевое слово throws? [0%] #5. Как создать собственное («пользовательское») исключение? [2%] #6. Расскажите про механизм обработки исключений в java (Try-catch-finally) [7%] #7. Возможно ли использование блока try-finally (без catch)? [0%] #8. Может ли один блок catch отлавливать сразу несколько исключений? [1%] #9. Всегда ли выполняется блок finally? Существуют ли ситуации, когда блок finally не будет выполнен? [1%] #10. В каком порядке следует обрабатывать исключения в catch блоках? [2%] #11. Что такое механизм try-with-resources? [2%] #12. Ошибка OutOfMemoryError. Поймать утечку памяти и пофиксить [8%] #13. @SneakyThrows в Lombok [2%] #14. StackOverflowError vs OutOfMemoryError [4%] #Дженерики [23%] #1. Что такое дженерики? Для чего нужны? [12%] #2. Что такое сырые типы? [0%] #3. Что такое вайлдкард [1%] #4. Расскажите про принцип PECS [7%] #5. Расскажите про класс Optional [8%] #6. Как JVM работает с Generics [2%] #Функциональные интерфейсы [18%] #1. Что такое функциональный интерфейс? [11%] #2. Для чего нужна аннотация @FunctionalInterface [2%] #3. Какие встроенные функциональные интерфейсы вы знаете? [6%] #4. Что такое ссылка на метод? [2%] #5. Что такое лямбда выражение? Чем его можно заменить? [8%] #6. Что делает Интерфейс Function [1%] #Stream API [35%] #1. Что такое Stream Api и для чего нужны Stream? [13%] #2. Почему Stream называют ленивым? [5%] #3. Какие существуют способы создания Stream? [0%] #4. Типы методов в Stream API [6%] #5. Методы в Stream API [0%] #6. Расскажите про класс Collectors и его методы [0%] #7. Что такое IntStream и DoubleStream? [0%] #8. Разница между parallel и parallerStream? [1%] #9. Для чего нужны операции Consumer, Function, Supplier [1%] #10. Что такое параллельные стримы? [5%] #11. Какая разница между findAny() и findFirst() [4%] #Многопоточность [47%] #1. Что такое многопоточность? [2%] #2. Чем процесс отличается от потока? [4%] #3. Чем Thread отличается от Runnable? Когда использовать Thread, а когда Runnable? [0%] #4. Что такое монитор? Как реализован в Java? [2%] #5. Что такое синхронизация? Какие способы синхронизации существуют в Java? [11%] #6. Что такое FutureTask? [2%] #7. Что такое ExecutorService? [4%] #8. Как работать с коллекциями в многопоточном программировании? [0%] #9. SynchronizedCollections. Что это? За счет чего достигается потокобезопасность? [0%] #10. Проблемы многопоточности [11%] #11. Atomic vs Volatile [8%] #12. Какие бывают состояния у потока? [0%] #13. Collections.synchronizedMap vs ConcurrentHashMap [4%] #14. Какими способами можем запустить несколько потоков в Java приложении? Как запустить поток в Java? [6%] #15. Что за интерфейсы Runnable и Callable? В чем между ними отличия? [7%] #16. Расскажи про пакет concurrent [2%] #17. Способы решения задач для многопоточного доступа [1%] #18. Чем конкурентность отличается от параллелизма? [1%] #19. Что такое CAS операции? (Compare And Swap) [4%] #20. Асинхронность vs многопоточность [1%] #21. Зачем нужны пулы потоков? [1%] #22. Что значит потокобезопасность? [1%] #23. Области памяти в многопоточности? [2%] #24. Executors.newCachedThreadPool() [1%] #25. Что такое happens-before? [5%] #26. ForkJoinPool vs FixedThreadPool [1%] #Базы данных [18%] #1. Виды БД и для чего их лучше использовать? [5%] #2. Масштабирование. Как решить нехватку места на сервере? [2%] #3. Репликация базы данных. Что это такое?[6%] #4. Что такое шардирование? [8%] #5. NoSQL vs SQL [4%] #6. Партиционирование [7%] #SQL [76%] #1. Что такое транзакции? [12%] #2. Расскажите про ACID [17%] #3. Проблемы параллельных транзакций [5%] #4. Уровни изолированности (read uncommitted, read committed, repeatable read, serializable) [27%] #5. Виды JOIN. Как работает каждый JOIN? [12%] #6. Индексы в SQL. Что это? [28%] #7. Нормализация и денормализация. Перечислите формы [10%] #8. Что такое внешний ключ? [0%] #9. Чем WHERE отличается от HAVING? Можем ли мы их использовать в одном запросе? [11%] #10. Чем отличается MySQL от PostgreSQL? [0%] #11. Оптимизация запросов. Какие инструменты? [12%] #12. EXPLAIN vs EXPLAIN ANALYZE [17%] #13. PostgreSQL. Какой инструмент для сбора статистики? PGSTAT [1%] #14. Что такое селективность? [2%] #15. Ключевое слово LATERAL [1%] #16. Оконные функции. PARTITION BY [4%] #17. cube, rollup, groupBy [1%] #18. Хранимые процедуры [5%] #19. Как работает Serializable? [1%] #20. View, materialized view. представлениями, материализованными представлениями? [4%] #21. C помощью SQL блокировка строки? - SELECT FOR UPDATE [4%] #22. UNION vs UNION ALL [4%] #23. Расскажи про ключевое слово DISTINCT? [1%] #24. Что такое табличные выражения? [1%] #25. Для чего используется Database Connection Pool? (Hikari) Переполнение connection pool [1%] #26. Блокировки и локи. Оптимистичная и Пессимистичная [14%] #27. БД. Constraint. Какие существуют? [2%] #28. Primary Key [2%] #29. Foreign Key [5%] #30. DELETE vs TRUNCATE [1%] #NoSQL [1%] #1. NoSQL типы БД [1%] #2. Для чего используется Redis? [1%] #3. Что такое Кэш? [1%] #Миграции [5%] #1. Liquibase. Что это и для чего? [4%] #2. Какие записи создаёт liquibase во время миграции? [2%] #3. Зачем нужны инструменты миграции? [1%] #ORM [59%] #1. Что такое Hibernate, JPA, JDBC, ORM? [11%] #2. Плюсы и минусы ORM [2%] #3. Как создать Entity и что это такое? [5%] #4. Может ли Entity наследоваться от не-Entity классов? [0%] #5. Может ли Entity наследоваться от других Entity классов? [0%] #6. Почему мы не можем использовать final классы в качестве Entity? [0%] #7. Что такое Proxy и для чего используется? [11%] #8. FetchType [2%] #9. Жизненный цикл сущности [5%] #10. Кэширование [10%] #11. HQL и JPQL [1%] #12. EntityManager + EntityManagerFactory / SessionFactory + session [5%] #13. Проблема N + 1 [27%] #14. Что такое Entity Graph? [6%] #15. Statement, Prepared statement, Callable statement [0%] #16. Связи между таблицами в ORM [2%] #17. LazyInitializationException [6%] #18. Что такое SQL-инъекция? [1%] #19. Проблемы JOIN FETCH [0%] #20. Логи в Hibernate [1%] #21. Аннотация @Query, что это такое? [1%] #22. Как Hibernate генерирует SQL запросы? [1%] #23. Hibernate. Что хранится в Persistence Context? Сколько времени объект хранится в Psersistence Context? [2%] #24. Hibernate и Lombok [2%] #25. Как JPA делает запросы? [1%] #Spring [82%] #1. Зачем мы используем Spring? Почему его так любят? [20%] #2. Inversion of Control [16%] #3. Dependency Injection [25%] #4. @Autowired [5%] #5. @Qualifier vs @Primary [17%] #6. Что такое Bean? [18%] #7. Скоуп бинов. Веб скоуп #8. Жизненный цикл Bean. Вопросы связанные с классами входящими в жизненный цикл бина [23%] #9. @ComponentScan [2%] #10. @Conditional в Spring [7%] #11. @Service, @Repository, @Component [11%] #12. @Controller и @RestController [8%] #13. @ResponseBody vs ResponseEntity [0%] #14. Spring MVC. Что это? Какие проблемы решает? [4%] #15. Парадигма AOP [5%] #16. Циклическая зависимость [5%] #17. Spring Boot [12%] #18. Spring JDBC [1%] #19. Spring Data JPA [5%] #20. Блокировка по умолчанию в Spring [1%] #21. @Transactional. Как работает? [31%] #22. @Async [2%] #23. Starter в Spring. Плюсы и минусы [8%] #24. Spring Criteria API [2%] #25. @Scheduled [5%] #26. Понятие Controller и Servlet в Java. Это одно и то же? Если разное, в чем отличия? [2%] #27. Что такое объект Filter? В какой момент вызывается? [2%] #28. Что такое ApplicationContext? [4%] #29. Зачем нужны аннотации @RequestParam и @PathVariable? [1%] #30. @ConfigurationProperties? ConfigurationProperties vs Value [4%] #31. @Value. Что это? [2%] #32. Как работает DispatcherServlet? [1%] #33. Варианты обработки Exceptions в Spring [4%] #34. @Configuration. Является Configuration компонентом? Какую доп логику Configuration реализует? [1%] #35. @PostConstruct [5%] #36. Dependency management в Spring boot [1%] #37. Spring Security, как хранить пароль пользователя? [2%] #38. Spring Profiles как с ними работать? [2%] #39. Виды proxy в Spring [4%] #40. @Lookup [4%] #Паттерны проектирования [19%] #1. GOF паттерны [7%] #2. Что такое паттерн? [0%] #3. Плюсы и минусы использования паттернов [0%] #4. Какие существуют группы паттернов? [4%] #5. Какие паттерны в какую группу входят? [1%] #6. Adapter vs Decorator [0%] #7. Паттерн MVC [2%] #8. Паттерн Command [1%] #9. Паттерн Chain of responsibility [1%] #10. Как реализуется паттер Abstract Factory? [2%] #11. Какие паттерны проектирования используются в Spring [4%] #12. Плюсы и минусы паттерна Singleton? [5%] #Web [22%] #1. REST [5%] #2. RESTful и RESTless [2%] #3. REST vs SOAP [1%] #4. В каких ситуациях допустимо использование RESTless [0%] #5. REST vs RPC. Как выбрать что лучше подходит? [1%] #6. Назовите 6 принципов REST API [0%] #7. Идемпотентный метод [4%] #8. Основные HTTP методы [6%] #9. Статусы ответов [1%] #10. GET vs POST [5%] #11. Разница HTTP и HTTPs [1%] #12. Из чего состоит HTTP запрос [1%] #13. Какие методы авторизации существуют для HTTP протокола? [1%] #14. Из чего состоит JSON Web Token? [2%] #15. Какие протоколы уровня приложений? [1%] #16. Что такое HTTP? [1%] #17. За что отвечают Cookie/куки? [1%] #18. Отличия POST, PUT, PATCH [2%] #Микросервисы [14%] #1. Монолит vs Микросервис [5%] #2. Паттерн Saga в микросервисной архитектуре [4%] #3. CAP теорема [2%] #4. Паттерн Circuit Breaker [1%] #5. Паттерн API Gateway [1%] #6. HTTP vs Kafka. Какой способ общения между микросервисами лучше и почему? [0%] #Брокеры сообщений [48%] #1. Плюсы и минусы брокеров сообщений [5%] #2. Разница между Kafka и RabbitMQ [5%] #3. Что такое топик в Kafka? [11%] #4. Что такое Producer и что такое Consumer [1%] #5. Что такое partition в Kafka? [13%] #6. Гарантии доставки в Kafka [7%] #7. Какие существуют паттерны работы с очередями? [1%] #8. Основные компоненты Kafka? [8%] #9. Kafka. Consumer Group [12%] #10. Из чего состоит Kafka кластер? [1%] #11. Брокеры сообщений vs Rest [7%] #12. Pull и push модели, в чём разница? [1%] #13. Как гарантировать в Kafka идемпотентность, чтобы не было задвоений и потерь сообщений? [4%] #14. Как в Kafka гарантируется последовательность сообщений? [2%] #15. Что сделать, чтобы сообщения попадали в одну партицию? [1%] #16. Как работает Round Robin? [1%] #17. Acknowledgment в Kafka [1%] #18. Смещение (offset) в Kafka [2%] #19. Повторное чтение данных из Kafka [1%] #20. DLQ topic? [1%] #Тестирование [11%] #1. На чем пишутся тесты? [2%] #2. Mock vs spy [2%] #3. Параметризованные тесты [1%] #4. Unit тесты. Что это и зачем? [1%] #5. Unit тесты vs интеграционные тесты [2%] #6. Mock. Как работает? [4%] #7. Spy. Как работает? [1%] #8. Каким образом проверяются результаты тестов? [1%] #Деплой [14%] #1. CI/CD [7%] #2. Как работает Docker. Из чего состоит докер образ? [4%] #3. Что такое слой? Как мы можем создать новый слой? [1%] #4. Docker compose [4%] #5. ARG, ENV. В чем отличия? [1%] #6. Docker cmd vs entrypoint [1%] #7. Отличия контейнеризации от виртулизации [2%] #8. Поддержка сервиса в продакшене, мониторинг его работы. Общие подходы? [1%] #Другое [8%] #1. Инструменты для отладки приложения, течет память, все замирает - Visual VM, JMap, профилировщики [2%] #2. Для чего нужно O большое в алгоритмах? (Что такое сложность в алгоритме) [6%] #