Java | Вопросы собесов – Telegram
Java | Вопросы собесов
11.4K subscribers
32 photos
2 videos
1.13K links
Download Telegram
Что такое spring boot и в чём его основное преимущество ?
Спросят с вероятностью 12%

Spring Boot — это проект, целью которого является упрощение процесса создания, конфигурации и развертывания приложений. Это делается за счет предоставления "готовых к использованию" настроек по умолчанию, что позволяет быстро и легко начать работу над новыми проектами.

Основные преимущества:

1️⃣ Быстрый старт: Предлагает ряд стартовых зависимостей (starters), которые автоматически настраивают Spring и связанные с ним компоненты для конкретных сценариев использования, позволяя разработчикам сосредоточиться на бизнес-логике приложения.

2️⃣ Автоконфигурация: Автоматически конфигурирует ваше приложение на основе добавленных в проект библиотек, снижая необходимость в ручной настройке и XML-конфигурациях.

3️⃣ Встроенные сервера приложений: Позволяет легко встраивать серверы приложений, такие как Tomcat, Jetty или Undertow, непосредственно в ваше приложение, упрощая развертывание и тестирование.

4️⃣ Управление зависимостями: Управляет версиями всех зависимостей, гарантируя совместимость и устраняя конфликты.

5️⃣ Продуктивность и независимость: Приложения, созданные с помощью него, могут быть независимыми и самодостаточными, что облегчает их развертывание и запуск.

6️⃣ Простота в развертывании: Приложения могут быть легко упакованы в один исполняемый JAR-файл с включенными всеми необходимыми зависимостями, что делает процесс развертывания простым и удобным.

7️⃣ Актуаторы: Spring Boot предоставляет актуаторы, предоставляющие готовые конечные точки для мониторинга и управления вашим приложением во время его выполнения.

8️⃣ Поддержка разработки: Spring Boot включает в себя инструменты для горячей перезагрузки кода и автоматической перекомпиляции, ускоряя процесс разработки.

Spring Boot значительно упрощает процесс разработки приложений на основе Spring, обеспечивая быстрый старт и минимизацию конфигурации, что делает его идеальным инструментом для разработчиков, стремящихся быстро создавать и развертывать микросервисы и веб-приложения.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍117
Какую структуру данных реализуем в LinkedList ?
Спросят с вероятностью 12%

LinkedList реализует структуру данных, известную как двусвязный список (doubly linked list). Эта структура состоит из набора узлов, где каждый узел содержит три части: данные (значение элемента) и две ссылки на соседние узлы — предыдущий и следующий. Таким образом, каждый элемент списка имеет ссылку на предыдущий и следующий элементы в списке, что позволяет эффективно выполнять операции вставки и удаления, поскольку не требуется перемещать другие элементы.

Основные особенности:

Двунаправленность: Благодаря ссылкам на предыдущий и следующий элементы, обход списка можно осуществлять как в прямом, так и в обратном направлении.
Динамический размер: Может динамически изменять свой размер, добавляя или удаляя элементы, без необходимости перевыделения памяти, как в случае с массивами.
Эффективное добавление/удаление: Добавление и удаление элементов в любой части списка, особенно в начале или конце, выполняется быстро, поскольку не требует сдвига остальных элементов.
Потребление памяти: Каждый элемент списка занимает больше памяти по сравнению с массивами из-за дополнительного хранения ссылок на предыдущий и следующий элементы.

Использование:

Реализует интерфейсы List, Deque и Queue, что делает его очень гибким инструментом. Он может использоваться как список, двусторонняя очередь или как очередь FIFO (First-In-First-Out). Эта гибкость делает эту структуру подходящим для различных сценариев, включая реализацию стеков, очередей, деков и других структур данных.

Пример использования:
import java.util.LinkedList;

public class LinkedListExample {
public static void main(String[] args) {
LinkedList<String> names = new LinkedList<>();

// Добавление элементов
names.add("Alice");
names.addFirst("Bob"); // Добавление в начало списка
names.addLast("Charlie"); // Добавление в конец списка

// Удаление элементов
names.removeFirst(); // Удаление первого элемента
names.removeLast(); // Удаление последнего элемента

// Обход списка
for (String name : names) {
System.out.println(name);
}
}
}


LinkedList предпочтителен, когда ваши основные операции — это добавление и удаление элементов, особенно если они происходят в начале или конце списка. Однако, если вам часто нужно получать доступ к элементам по индексу, ArrayList может быть более эффективным выбором из-за быстрого произвольного доступа к элементам.

➡️Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍102
Какую структуру данных реализуем в LinkedList ?
Спросят с вероятностью 12%

LinkedList реализует структуру данных, известную как двусвязный список (doubly linked list). Эта структура состоит из набора узлов, где каждый узел содержит три части: данные (значение элемента) и две ссылки на соседние узлы — предыдущий и следующий. Таким образом, каждый элемент списка имеет ссылку на предыдущий и следующий элементы в списке, что позволяет эффективно выполнять операции вставки и удаления, поскольку не требуется перемещать другие элементы.

Основные особенности:

Двунаправленность: Благодаря ссылкам на предыдущий и следующий элементы, обход списка можно осуществлять как в прямом, так и в обратном направлении.
Динамический размер: Может динамически изменять свой размер, добавляя или удаляя элементы, без необходимости перевыделения памяти, как в случае с массивами.
Эффективное добавление/удаление: Добавление и удаление элементов в любой части списка, особенно в начале или конце, выполняется быстро, поскольку не требует сдвига остальных элементов.
Потребление памяти: Каждый элемент списка занимает больше памяти по сравнению с массивами из-за дополнительного хранения ссылок на предыдущий и следующий элементы.

Использование:

Реализует интерфейсы List, Deque и Queue, что делает его очень гибким инструментом. Он может использоваться как список, двусторонняя очередь или как очередь FIFO (First-In-First-Out). Эта гибкость делает эту структуру подходящим для различных сценариев, включая реализацию стеков, очередей, деков и других структур данных.

Пример использования:
import java.util.LinkedList;

public class LinkedListExample {
public static void main(String[] args) {
LinkedList<String> names = new LinkedList<>();

// Добавление элементов
names.add("Alice");
names.addFirst("Bob"); // Добавление в начало списка
names.addLast("Charlie"); // Добавление в конец списка

// Удаление элементов
names.removeFirst(); // Удаление первого элемента
names.removeLast(); // Удаление последнего элемента

// Обход списка
for (String name : names) {
System.out.println(name);
}
}
}


LinkedList предпочтителен, когда ваши основные операции — это добавление и удаление элементов, особенно если они происходят в начале или конце списка. Однако, если вам часто нужно получать доступ к элементам по индексу, ArrayList может быть более эффективным выбором из-за быстрого произвольного доступа к элементам.

➡️Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍10
Что такое принципы SOLID ?
Спросят с вероятностью 12%

Принципы SOLID — это набор из пяти основополагающих принципов объектно-ориентированного программирования и дизайна, предложенных Робертом Мартином. Эти принципы направлены на улучшение читаемости, поддерживаемости и расширяемости кода, а также на уменьшение его сложности и увеличение гибкости. Этот набор является аббревиатурой, где каждая буква обозначает определённый принцип:

S - Принцип единственной ответственности (Single Responsibility Principle)

Каждый класс должен иметь только одну причину для изменения, что означает, что класс должен выполнять только одну задачу или функцию. Это упрощает понимание и тестирование класса, а также уменьшает его сложность.

O - Принцип открытости/закрытости (Open/Closed Principle)

Классы, модули, функции и т.д. должны быть открыты для расширения, но закрыты для модификации. Это означает, что поведение модуля можно изменить или расширить, не изменяя его исходный код, например, с помощью наследования или паттернов проектирования.

L - Принцип подстановки Лисков (Liskov Substitution Principle)

Объекты в программе должны быть заменяемыми на экземпляры их подтипов без изменения правильности выполнения программы. Этот принцип подчёркивает важность совместимости интерфейсов при наследовании и реализации.

I - Принцип разделения интерфейса (Interface Segregation Principle)

Клиенты не должны зависеть от интерфейсов, которые они не используют. Этот принцип предполагает, что лучше иметь много специализированных интерфейсов, чем один "универсальный".

D - Принцип инверсии зависимостей (Dependency Inversion Principle)

Модули высокого уровня не должны зависеть от модулей низкого уровня. Оба типа модулей должны зависеть от абстракций. Кроме того, абстракции не должны зависеть от деталей, а детали — от абстракций. Этот принцип направлен на уменьшение зависимостей между модулями кода.

Применение принципов SOLID в разработке ПО помогает создавать системы, которые легче понимать, развивать и поддерживать. Это достигается за счёт уменьшения жёсткой зависимости между компонентами, упрощения модификации и расширения кода, а также облегчения тестирования и рефакторинга. Принципы SOLID также способствуют созданию более гибких и масштабируемых архитектур программных систем.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍212🔥1
Что такое bean, какую роль играет в Spring'е ?
Спросят с вероятностью 12%

Термин "bean" относится к объекту, который управляется контейнером Spring IoC (Inversion of Control). Bean — это фундаментальная концепция, которая позволяет фреймворку автоматически управлять созданием, настройкой и управлением жизненным циклом объектов приложения.

Роль и особенности:

1️⃣Управление жизненным циклом: Создаёт, инициализирует и уничтожает бины. Разработчики могут настроить эти процессы с помощью аннотаций или XML-конфигурации.

2️⃣Внедрение зависимостей (Dependency Injection, DI): Могут автоматически получать свои зависимости от контейнера. Это освобождает разработчиков от необходимости вручную создавать и связывать объекты, делая код более чистым и модульным.

3️⃣Объединение конфигурации: Их конфигурация может быть централизованно определена в конфигурационных файлах XML или с помощью аннотаций в классах. Это упрощает управление конфигурацией приложения.

4️⃣Поддержка аспектно-ориентированного программирования (AOP): Spring бины могут быть легко интегрированы с аспектами для реализации поперечной функциональности, такой как транзакции или логирование.

5️⃣Повторное использование: Контейнер управляет одиночными экземплярами (singleton) бинов по умолчанию, что способствует их повторному использованию и уменьшает потребление ресурсов.

Определение и создание:

Бин можно определить в XML-конфигурации Spring или с помощью аннотаций в классе. Аннотации, такие как @Component, @Service, @Repository, и @Controller, автоматически определяют класс как бин и указывают его роль в приложении.

Пример с аннотацией @Component:
@Component
public class MyService {
// Класс определён как бин
}


XML-конфигурация для определения бина:
<bean id="myService" class="com.example.MyService"/>


Бины являются центральными элементами приложений на Spring, позволяя фреймворку брать на себя ответственность за многие аспекты управления объектами. Это включает в себя создание объектов, внедрение зависимостей, управление конфигурацией и поддержку аспектно-ориентированного программирования, что в совокупности делает разработку на Spring более эффективной и организованной.

➡️Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍222🤯2
Как можно описать абстракцию ?
Спросят с вероятностью 12%

Абстракция — это фундаментальный принцип, заключающийся в выделении важных характеристик некоторого объекта или явления и игнорировании несущественных деталей. Этот принцип позволяет сосредоточиться на том, что объект делает, а не на том, как он это делает, упрощая тем самым проектирование и разработку ПО.

Основные аспекты:

1️⃣ Упрощение: Абстракция помогает упростить сложные реальные ситуации, выделяя основные аспекты и игнорируя менее важные детали. Это позволяет разработчикам создавать более понятные и управляемые модели.

2️⃣ Повторное использование: Абстракция способствует повторному использованию кода, поскольку абстрактные конструкции могут быть реализованы и адаптированы для решения различных задач без изменения основного кода.

3️⃣ Инкапсуляция: Абстракция тесно связана с инкапсуляцией, так как она позволяет скрыть внутреннюю реализацию деталей и предоставить пользователю только необходимый интерфейс для взаимодействия с объектом.

4️⃣ Модульность: Применение абстракции способствует разделению программы на модули, каждый из которых решает свою задачу. Это облегчает понимание, тестирование и поддержку кода.

Примеры:

Абстрактные классы и интерфейсы в объектно-ориентированном программировании (ООП): ООП использует абстрактные классы и интерфейсы для определения и группирования связанных методов без реализации. Конкретные классы затем наследуют абстрактный класс или реализуют интерфейсы, предоставляя специфическую реализацию.

API (Application Programming Interface): API предоставляет абстрактный интерфейс для взаимодействия с программным обеспечением или системой, скрывая сложность реализации и позволяя разработчикам использовать предопределенные функции для достижения своих целей.

Паттерны проектирования: Многие паттерны проектирования, такие как фабрика, стратегия или фасад, основаны на принципах абстракции, позволяя разработчикам создавать гибкие и масштабируемые архитектуры программных систем.

Абстракция — это ключевой принцип в разработке ПО, позволяющий управлять сложностью системы, улучшать её структуру и обеспечивать гибкость для будущего расширения и модификации. Этот принцип находит применение в различных аспектах программирования, от проектирования архитектуры до реализации конкретных функций и интерфейсов.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍17🤯21🤔1🎉1
Чем отличается операция map от flatMap ?
Спросят с вероятностью 19%

Операции map и flatMap являются важными концепциями в функциональном программировании и широко используются во многих языках программирования, в контексте работы с коллекциями и потоками данных (streams). Хотя обе операции применяют функцию к элементам потока или коллекции, между ними есть ключевые отличия в поведении и результате выполнения.

Операция map

Применяет заданную функцию к каждому элементу коллекции или потока и возвращает новую коллекцию или поток, состоящий из результатов применения этой функции. Важно отметить, что при ее использовании количество элементов во входной и выходной коллекции (или потоке) остается неизменным.
List<Integer> numbers = Arrays.asList(1, 2, 3, 4);
List<Integer> squaredNumbers = numbers.stream()
.map(n -> n * n)
.collect(Collectors.toList());
// squaredNumbers будет содержать [1, 4, 9, 16]


Операция flatMap

Также применяет заданную функцию к каждому элементу коллекции или потока, но с одним существенным отличием: ожидается, что функция для каждого элемента вернет поток (или коллекцию) элементов, а flatMap "сплющивает" все эти потоки (или коллекции) в один поток. Таким образом, его удобно использовать, когда результатом применения функции является коллекция или поток, и вы хотите получить плоский список всех элементов, а не коллекцию коллекций.
List<List<Integer>> listOfLists = Arrays.asList(
Arrays.asList(1, 2),
Arrays.asList(3, 4, 5)
);
List<Integer> flatList = listOfLists.stream()
.flatMap(Collection::stream)
.collect(Collectors.toList());
// flatList будет содержать [1, 2, 3, 4, 5]


Основные отличия:

Результат: map преобразует каждый элемент коллекции отдельно и возвращает коллекцию того же размера. flatMap может преобразовывать каждый элемент в несколько элементов и "сплющивает" результат в одну коллекцию, что может изменить количество элементов в итоговой коллекции.
Использование: map используется для простых преобразований элементов, а flatMap — для преобразований, при которых каждый элемент может быть представлен несколькими элементами в результате.

Выбор между map и flatMap зависит от конкретной задачи и желаемой структуры выходных данных.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍341
Что такое столп "наследование" ?
Спросят с вероятностью 12%

Наследование — это один из ключевых принципов ООП, позволяющий создавать новые классы на основе существующих. Наследование обеспечивает механизм для повторного использования кода и иерархическую организацию классов, что способствует упрощению разработки и поддержки программного обеспечения.

Основные аспекты:

1️⃣ Повторное использование кода: Позволяет новому классу (производному или подклассу) автоматически включать в себя все публичные и защищённые атрибуты и методы базового класса (родительского или суперкласса). Это уменьшает дублирование кода и упрощает его поддержку.

2️⃣ Расширение функциональности: Подклассы могут не только наследовать функциональность родительского класса, но и расширять её, добавляя новые методы и свойства, а также переопределяя существующие.

3️⃣ Полиморфизм: Является основой для полиморфизма — способности методов обрабатывать объекты разных классов, которые имеют общий родительский класс, в единой иерархии классов. Это позволяет использовать один и тот же код для работы с объектами разных типов, что увеличивает гибкость и переиспользуемость кода.

4️⃣ Иерархическая организация: Позволяет строить иерархические структуры классов, что облегчает понимание связей между различными компонентами системы и упрощает моделирование реальных объектов и явлений.

Пример:
// Базовый класс
class Vehicle {
void move() {
System.out.println("Транспортное средство движется");
}
}

// Производный класс
class Car extends Vehicle {
@Override
void move() {
super.move(); // Вызов метода из базового класса
System.out.println("Автомобиль едет по дороге");
}

void openDoor() {
System.out.println("Дверь открыта");
}
}

public class Main {
public static void main(String[] args) {
Car myCar = new Car();
myCar.move(); // Используется переопределённый метод
myCar.openDoor(); // Используется новый метод
}
}


В этом примере класс Car наследуется от класса Vehicle, переопределяет его метод move() и добавляет новый метод openDoor(). Это демонстрирует, как наследование позволяет расширять и модифицировать поведение базового класса, а также вводить новую функциональность в производные классы.

Наследование является мощным инструментом в ООП, позволяющим строить сложные и гибкие системы с повторным использованием кода и логической организацией. Однако его следует использовать осмотрительно, чтобы избежать излишней сложности и жёсткой связанности классов.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍141😁1🤯1
Что такое синхронизация и зачем она нужна ?
Спросят с вероятностью 12%

Синхронизация — это механизм, который используется для контроля доступа к общим ресурсам или критическим секциям кода в среде, где несколько потоков или процессов могут одновременно выполняться. Основная цель — обеспечить корректное взаимодействие между потоками, предотвращая одновременное выполнение определённых участков кода, которые могут привести к конфликтам или неконсистентному состоянию данных.

Зачем она нужна:

1️⃣Предотвращение гонки данных (race conditions): Гонка данных возникает, когда два или более потоков одновременно пытаются изменить общие данные, и результат выполнения зависит от того, в каком порядке потоки выполняют операции. Синхронизация помогает управлять доступом к данным таким образом, чтобы обеспечить их целостность.

2️⃣Обеспечение видимости изменений: В многопоточной среде изменения, сделанные одним потоком в общем ресурсе, могут не быть сразу видны другим потокам из-за кэширования данных в процессорах или оптимизаций компилятора. Синхронизация гарантирует, что изменения, сделанные одним потоком, будут корректно видны другим потокам.

3️⃣Последовательный доступ к ресурсам: Некоторые операции или ресурсы требуют последовательного доступа для предотвращения конфликтов или некорректной работы. Например, запись в файл или обновление базы данных должны выполняться последовательно, чтобы избежать наложения данных или повреждения структуры данных.

Как она реализуется:

Может быть реализована с использованием следующих механизмов:

Ключевое слово synchronized: Может использоваться для блокировки целого метода или определённого блока кода, обеспечивая монопольный доступ к этому участку кода для одного потока одновременно.

Явные блокировки с использованием классов из пакета java.util.concurrent.locks: Предоставляют более гибкие возможности для управления блокировками, включая попытку захвата блокировки без ожидания, захват прерываемых блокировок и блокировки с возможностью повторного входа.

Волатильные переменные (volatile): Обеспечивают видимость изменений переменных между разными потоками, но не контролируют последовательность доступа к переменной.

Синхронизация необходима для обеспечения корректной работы многопоточных приложений, предотвращения ошибок синхронизации и гарантии безопасного взаимодействия потоков с общими ресурсами. Однако её использование следует минимизировать или применять осторожно, поскольку неправильное использование может привести к проблемам с производительностью, таким как узкие места (bottlenecks) или взаимные блокировки (deadlocks).

➡️Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
15👍7
Какие есть принципы ООП ?
Спросят с вероятностью 50%

Объектно-ориентированное программирование (ООП) основывается на четырех основных принципах, которые обеспечивают гибкость, масштабируемость и повторное использование кода. Эти принципы помогают создавать более чистый, понятный и надежный код.

1️⃣ Инкапсуляция

Сокрытие внутренних данных класса от внешнего мира и контроль доступа к этим данным с помощью методов класса. Это позволяет защитить данные от непреднамеренного изменения и создать четкий интерфейс взаимодействия с объектом.
public class Account {
private double balance; // Скрытие данных

public void deposit(double amount) {
if (amount > 0) {
balance += amount;
}
}

public double getBalance() {
return balance;
}
}


2️⃣ Наследование

Позволяет создать новый класс на основе существующего, перенимая его свойства и методы. Это облегчает повторное использование кода и упрощает создание иерархических классификаций.
public class Vehicle {
private String brand;

public void honk() {
System.out.println("Туут, туут!");
}
}

public class Car extends Vehicle {
private int numberOfSeats;

public void display() {
System.out.println("Марка: " + brand + ", Количество сидений: " + numberOfSeats);
}
}


3️⃣ Полиморфизм

Позволяет объектам с одинаковым интерфейсом иметь различную реализацию. Это означает, что одно и то же имя метода может использоваться для разных типов действий.
public class Animal {
public void sound() {
System.out.println("Животное издает звук");
}
}

public class Pig extends Animal {
public void sound() {
System.out.println("Хрю");
}
}

public class Dog extends Animal {
public void sound() {
System.out.println("Гав");
}
}


4️⃣ Абстракция

Означает выделение ключевых, наиболее значимых характеристик объекта, исключая из рассмотрения несущественные. Это позволяет сосредоточиться на том, что объект делает, а не на том, как он это делает.
public abstract class Shape {
abstract void draw();
}

public class Circle extends Shape {
void draw() {
System.out.println("Рисуем круг");
}
}

public class Square extends Shape {
void draw() {
System.out.println("Рисуем квадрат");
}
}


Эти четыре принципа ООП помогают создавать системы, которые легче поддаются модификации, тестированию и поддержке.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍251
Какие виды тестирования есть ?
Спросят с вероятностью 12%

Тестирование ПО — это процесс, направленный на оценку качества программного продукта и выявление ошибок в его работе. Существует множество видов тестирования, каждый из которых предназначен для проверки определённых аспектов программы. Различные виды тестирования могут применяться на разных этапах разработки и для разных целей. Вот некоторые из наиболее распространённых видов тестирования:

1️⃣ Модульное тестирование (Unit Testing)

Проверка отдельных модулей или компонентов программы для убеждения в их корректной работе. Каждый тест проверяет отдельную функцию или метод на предмет правильности выполнения задачи.

2️⃣ Интеграционное тестирование (Integration Testing)

Проверка взаимодействия между различными модулями или системными компонентами. Целью является выявление проблем в интерфейсах и взаимодействии между отдельными частями программы.

3️⃣ Системное тестирование (System Testing)

Тестирование программного продукта в целом для проверки его соответствия спецификациям и требованиям. Это включает в себя тестирование функциональности, производительности, безопасности и других аспектов программы.

4️⃣ Приёмочное тестирование (Acceptance Testing)

Проверка программного продукта на соответствие требованиям заказчика или пользователя. Обычно проводится в конце цикла разработки и является решающим фактором для принятия решения о выходе продукта на рынок.

5️⃣ Нагрузочное тестирование (Load Testing)

Проверка способности программы обрабатывать определённый объём задач или запросов за заданный промежуток времени. Целью является определение производительности и выявление узких мест.

6️⃣ Тестирование безопасности (Security Testing)

Проверка ПО на уязвимости, угрозы и другие риски безопасности. Включает в себя поиск уязвимостей, которые могут быть использованы для несанкционированного доступа или ущерба.

7️⃣ Регрессионное тестирование (Regression Testing)

Повторное тестирование программного обеспечения после внесения изменений для убеждения, что новый код не нарушил существующую функциональность и не привёл к новым ошибкам.

8️⃣ Usability Testing (Тестирование удобства использования)

Оценка того, насколько легко и удобно конечным пользователям взаимодействовать с программным продуктом. Включает проверку интуитивности интерфейса, лёгкости освоения и общего удобства использования.

Существует множество видов тестирования, каждый из которых выполняет свою роль в процессе разработки ПО. Правильный выбор и сочетание методов тестирования позволяют обеспечить высокое качество продукта и удовлетворённость пользователя.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍19🤔1
Какой принцип SOLID нарушается, если класс зависит от конкретных классов, а не абстракций?
Anonymous Quiz
10%
Single Responsibility Principle
9%
Open/Closed Principle
60%
Dependency Inversion Principle
21%
Interface Segregation Principle
🔥14
В чём различие между интерфейсом и абстрактным классом ?
Спросят с вероятностью 56%

Интерфейс и абстрактный класс используются для достижения абстракции, но между ними существуют ключевые различия, связанные с их использованием и целями.

Интерфейс

Это контракт или соглашение, которое класс может реализовать. Определяют методы без их реализаций, оставляя классам, которые их реализуют, определять конкретные действия. В Java 8 и более поздних версиях интерфейсы могут содержать статические методы с реализацией и методы по умолчанию, которые имеют реализацию. Класс может реализовывать несколько интерфейсов, что поддерживает множественное наследование поведения.

Абстрактный класс

Это класс, не предназначенный для создания экземпляров, который может содержать как абстрактные методы (без реализации), так и методы с реализацией. Предназначен для того, чтобы быть базовым классом, от которого будут наследовать другие классы и реализовывать абстрактные методы. Класс может наследовать только один абстрактный класс, что ограничивает множественное наследование.

Основные различия

1️⃣ Наследование: Класс может реализовать множество интерфейсов, но наследовать только один абстрактный класс.
2️⃣ Методы: Интерфейсы могут содержать только объявления методов (до Java 8) и статические методы, а также методы по умолчанию (начиная с Java 8), тогда как абстрактные классы могут содержать как абстрактные методы, так и методы с реализацией.
3️⃣ Конструкторы: Абстрактные классы могут иметь конструкторы, интерфейсы — нет.
4️⃣ Поля: В интерфейсах все поля являются публичными, статическими и финальными по умолчанию, а абстрактные классы могут содержать поля с любым уровнем доступа и без ограничений на статичность или финализацию.
5️⃣ Использование: Абстрактные классы используются, когда несколько классов имеют общую реализацию, но также и свою уникальную реализацию некоторых методов. Интерфейсы идеально подходят для определения общего контракта для разнородных классов, которые не обязательно связаны друг с другом через иерархию наследования.

Выбор между интерфейсом и абстрактным классом зависит от конкретной ситуации в проектировании программы. Если нужно определить общий контракт для классов, которые могут принадлежать к разным иерархиям наследования, следует использовать интерфейс. Если же требуется общая реализация для схожих классов, то лучше подойдет абстрактный класс.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍50🔥42
Что такое CI/CD ?
Спросят с вероятностью 12%

CI/CD — это сокращение, обозначающее Continuous Integration (Непрерывная интеграция) и Continuous Delivery/Continuous Deployment (Непрерывная доставка/Непрерывное развёртывание). Это практики в области разработки ПО, которые направлены на ускорение и автоматизацию процессов интеграции изменений в код, тестирования и развёртывания приложений.

Continuous Integration (CI)

Непрерывная интеграция — это практика разработки программного обеспечения, при которой разработчики регулярно, часто несколько раз в день, интегрируют свои изменения в общий репозиторий проекта. После каждой интеграции автоматически выполняется сборка и тестирование кода, что позволяет быстро обнаруживать и исправлять ошибки, улучшать качество кода и сокращать время, необходимое для релиза продукта.

Continuous Delivery

Непрерывная доставка — это расширение практики CI, которое обеспечивает автоматизацию всех этапов, необходимых для доставки версий программного продукта в тестовую или промежуточную среду. Цель — создать полностью автоматизированный процесс сборки, тестирования и подготовки к выпуску продукта, чтобы он был готов к непрерывному развёртыванию в любой момент.

Continuous Deployment

Непрерывное развёртывание — это дальнейшее развитие практики, при которой все изменения в коде, прошедшие через стадии сборки и тестирования, автоматически развёртываются в продуктивной среде. Это позволяет сделать процесс выпуска новых версий максимально быстрым и эффективным, минимизируя вмешательство человека в процесс развёртывания.

Применение позволяет:

Улучшить сотрудничество и продуктивность за счёт более частых обновлений кода и снижения количества конфликтов при слиянии изменений.
Ускорить время выхода продукта на рынок благодаря автоматизации рутинных операций и сокращению времени на тестирование и развёртывание.
Повысить качество продукта за счёт автоматического тестирования на каждом этапе и быстрого обнаружения ошибок.
Минимизировать риски за счёт непрерывного развёртывания маленьких изменений и возможности быстрого отката в случае обнаружения проблем.

CI/CD является ключевым компонентом современных методологий разработки, таких как Agile и DevOps, и способствует созданию более эффективного и гибкого процесса разработки ПО.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍153
Какие бывают ограничения в БД ?
Спросят с вероятностью 12%

Ограничения (constraints) в базах данных используются для определения правил для данных в таблице и обеспечения целостности данных. Они помогают предотвратить ввод некорректных данных в базу данных и поддерживают согласованность данных. Вот основные типы ограничений в базах данных:

1️⃣ PRIMARY KEY (Первичный ключ)

Данное ограничение идентифицирует каждую запись в таблице уникальным образом. Значения в столбце с таким ограничением должны быть уникальными и не могут быть NULL. В каждой таблице может быть только один первичный ключ, который может состоять из одного или нескольких полей.

2️⃣ FOREIGN KEY (Внешний ключ)

Данное ограничение используется для создания связи между таблицами. Оно обеспечивает, что значение в столбце (или группе столбцов) ссылающейся таблицы соответствует значению в столбце (или группе столбцов) родительской таблицы, на который этот столбец ссылается. Это ограничение используется для поддержания целостности ссылочных отношений между таблицами.

3️⃣ UNIQUE (Уникальность)

Данное ограничение гарантирует, что все значения в столбце или группе столбцов уникальны среди всех строк таблицы. В отличие от первичного ключа, столбец с ограничением UNIQUE может содержать NULL значения (если только явно не указано иное).

4️⃣ CHECK (Проверка)

Данное ограничение используется для определения допустимых значений, которые может принимать столбец. Оно позволяет задать условие, которому должно удовлетворять значение в столбце, например, что возраст должен быть больше 18.

5️⃣ NOT NULL

Данное ограничение обеспечивает, что столбец не может содержать значение NULL. Это гарантирует, что каждая строка в таблице должна содержать значение в этом столбце.

6️⃣ DEFAULT

Данное ограничение устанавливает значение по умолчанию для столбца, если при вставке строки значение для этого столбца не было указано. Это полезно, например, для установки текущей даты и времени для записей или установки начального статуса для новых записей.

Ограничения БД важны для обеспечения целостности и корректности данных. Они помогают автоматически применять бизнес-правила и логику на уровне базы данных, снижая риск ошибок и несогласованности данных, которые могут возникнуть из-за некорректных операций вставки, обновления или удаления данных.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍31
Что такое Spring контекст ?
Спросят с вероятностью 19%

Spring контекст, известный как Spring ApplicationContext, является центральным интерфейсом, обеспечивающим конфигурацию приложения и доступ к его компонентам (бинам). Этот контекст представляет собой расширенную форму IoC (Inversion of Control) контейнера, который управляет инстанцированием, конфигурацией и сборкой бинов в приложении.

Основные функции Spring контекста:

1️⃣ Управление бинами: Автоматически создает и управляет жизненным циклом всех бинов, определенных в конфигурации приложения. Эти бины могут быть сконфигурированы через XML, аннотации или Java-конфигурацию.

2️⃣ Внедрение зависимостей: Управляет внедрением зависимостей между бинами, позволяя разработчикам создавать более модульные и тестируемые приложения.

3️⃣ Предоставление ресурсов: Предоставляет доступ к файловым ресурсам, таким как текстовые и свойства файлы, облегчая их использование в приложении.

4️⃣ Поддержка интернационализации: Позволяет использовать ресурсы для локализации, поддерживая мультиязычность в приложении.

5️⃣ Публикация событий: Предоставляет возможность публиковать и слушать события в приложении, что позволяет компонентам взаимодействовать между собой асинхронно.

6️⃣ Прозрачная работа с технологиями предприятия: Облегчает работу с JNDI, EJB, валидацией, задачами и планированием, а также предоставляет интеграцию с веб-технологиями.

Примеры:

- Через XML конфигурацию:
<beans>
<bean id="myBean" class="com.example.MyClass"/>
</beans>


- Через аннотации:
@Component
public class MyComponent {
// Класс, который будет автоматически зарегистрирован как бин
}


- Через Java-конфигурацию:
@Configuration
public class AppConfig {
@Bean
public MyBean myBean() {
return new MyBean();
}
}


- Запуск:
ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml");
MyClass myClass = ctx.getBean("myBean", MyClass.class);


- Для Java-конфигурации:
ApplicationContext ctx = new AnnotationConfigApplicationContext(AppConfig.class);
MyBean myBean = ctx.getBean(MyBean.class);


Spring контекст играет ключевую роль в разработке приложений, обеспечивая инфраструктурную поддержку и управление зависимостями, что делает разработку проще и более эффективной.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍177
Что такое Servlet ?
Спросят с вероятностью 12%

Servlet — это технология на стороне сервера, используемая для создания веб-приложений на языке программирования. Он является интерфейсом, реализуемым в Java-приложениях для обработки запросов клиентов и генерации динамического содержимого в ответ. Он работает в контейнере сервлетов (например, Apache Tomcat, Jetty, JBoss), который обеспечивает сетевые соединения и управление ресурсами.

Ключевые особенности:

1️⃣ Жизненный цикл: Имеют определённый жизненный цикл, управляемый контейнером сервлетов. Основные этапы включают инициализацию (метод init()), обработку запросов (метод service() или doGet(), doPost() для HTTP-сервлетов), и завершение работы (метод destroy()).

2️⃣ Многопоточность: Обрабатывает множество запросов параллельно, используя отдельные потоки, что делает его высокопроизводительным решением для веб-приложений.

3️⃣ Безопасность: Могут использовать механизмы безопасности Java и веб-контейнера для аутентификации, авторизации и шифрования данных.

4️⃣ Переносимость: Приложения, основанные на сервлетах, могут быть легко перенесены между различными серверами и контейнерами, поддерживающими спецификацию сервлетов.

Пример:
import java.io.;
import javax.servlet.;
import javax.servlet.http.*;

public class HelloWorldServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<html><body>");
out.println("<h1>Hello, World</h1>");
out.println("</body></html>");
}
}


В этом примере сервлет генерирует простую HTML-страницу с текстом "Hello, World" в ответ на HTTP GET запрос.

Servlet является мощной основой для создания веб-приложений, обеспечивая гибкость в обработке запросов и генерации динамического контента. Благодаря поддержке стандартизированной спецификации, сервлеты обеспечивают высокую степень переносимости и интеграции с другими технологиями и фреймворками для веб-разработки.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍191🔥1
Какие Spring Scope есть ?
Спросят с вероятностью 44%

В Spring Framework существует несколько областей видимости (scopes) для бинов, каждая из которых определяет жизненный цикл и видимость бина в контексте приложения. Вот основные из них:

1️⃣ Singleton: Это область видимости по умолчанию. Бин с данной областью видимости создается один раз на каждый контейнер Spring IoC и кэшируется для последующих запросов. Все запросы на получение бина возвращают один и тот же экземпляр бина.
@Component
@Scope("singleton")
public class MySingletonBean {
}


2️⃣ Prototype: Бин с данной областью видимости создается заново каждый раз, когда он запрашивается из контейнера. Это полезно, когда необходимы разные экземпляры бина для разных задач.
@Component
@Scope("prototype")
public class MyPrototypeBean {
}


3️⃣ Request: Эта область видимости используется в веб-приложениях. Бин создается для каждого HTTP-запроса и уничтожается после обработки запроса. Бины с данной областью видимости доступны только в контексте одного HTTP-запроса.
@Component
@Scope(value = "request", proxyMode = ScopedProxyMode.TARGET_CLASS)
public class MyRequestBean {
}


4️⃣ Session: Бин с данной областью видимости создается для каждой пользовательской сессии. Бин живет в течение всей сессии и уничтожается, когда сессия завершается. Это полезно для хранения информации, специфичной для пользователя, в течение всего времени его сессии.
@Component
@Scope(value = "session", proxyMode = ScopedProxyMode.TARGET_CLASS)
public class MySessionBean {
}


5️⃣ Application: Бин с данной областью видимости создается один раз для всего сервлет-контекста. Это полезно для данных, которые должны быть общими для всех пользователей и сессий в приложении.
@Component
@Scope(value = "application", proxyMode = ScopedProxyMode.TARGET_CLASS)
public class MyApplicationBean {
}


6️⃣ WebSocket: Бин с данной областью видимости создается для каждой сессии WebSocket. Это полезно для работы с данными, специфичными для каждой WebSocket-сессии.
@Component
@Scope(value = "websocket", proxyMode = ScopedProxyMode.TARGET_CLASS)
public class MyWebSocketBean {
}


Каждая из этих областей видимости предоставляет разные способы управления жизненным циклом бинов в приложении, позволяя выбирать наиболее подходящий вариант для конкретного случая.

Spring предлагает разные области видимости для бинов, такие как Singleton, Prototype, Request, Session, Application и WebSocket, которые определяют, как и когда бины будут создаваться, жить и уничтожаться. Это позволяет управлять жизненным циклом бинов в соответствии с потребностями приложения.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍271🔥1
Чем rebase отличается от merge ?
Спросят с вероятностью 12%

rebase и merge являются двумя различными способами интеграции изменений из одной ветки git в другую. Оба метода используются для синхронизации изменений, но они делают это по-разному и служат разным целям.

Merge (слияние)

Используется для объединения изменений из одной ветки в другую. При выполнении слияния git создает новый коммит, который является "коммитом слияния" и имеет двух родителей — каждый из родительских коммитов представляет собой последние изменения в каждой из сливаемых веток.

Преимущества:
История коммитов сохраняет время и порядок всех изменений.
Коммиты слияния явно указывают на то, что произошло слияние двух веток.

Недостатки:
История коммитов может стать сложной и запутанной из-за большого количества коммитов слияния, особенно в проектах с активной разработкой и многими ветками.

Rebase (перебазирование)

Переносит коммиты из одной ветки на вершину другой ветки, изменяя базовый коммит. Это создает линейную историю, как если бы все изменения были выполнены последовательно, даже если они разрабатывались параллельно.

Преимущества:
Создает чистую, линейную историю коммитов, что облегчает понимание последовательности изменений.
Упрощает процесс обзора истории изменений перед вливанием в основную ветку.

Недостатки:
Может создать проблемы с сохранностью истории, если он выполняется на коммитах, уже опубликованных в общедоступном репозитории, так как это изменяет историю коммитов.
Требует большей осторожности и понимания процесса, поскольку может привести к потере изменений при неправильном использовании.

В чем разница?

Основное отличие между merge и rebase заключается в том, как они интегрируют изменения. Merge сохраняет историю ветвления и слияния, в то время как rebase создает линейную историю, как если бы все изменения были сделаны последовательно в одной ветке. Выбор между merge и rebase зависит от предпочтений команды и требований к управлению историей изменений в проекте.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍31
В чём разница между JDK и JRE ?
Спросят с вероятностью 19%

JDK (Java Development Kit) и JRE (Java Runtime Environment) — это две взаимосвязанные платформы, используемые для разработки и выполнения приложений, но они предназначены для разных целей.

Java Development Kit (JDK)

Является полным ПО для разработки, включающим в себя JRE (то есть всё, что нужно для запуска Java-приложений), а также компилятор Java (javac), стандартные Java библиотеки, инструменты для разработки и отладки программ (например, jdb для отладки). Предназначен для разработчиков Java-приложений, поскольку он предоставляет все необходимые инструменты для разработки, компиляции, отладки и запуска программ.

Java Runtime Environment (JRE)

Представляет собой часть ПО, которая необходима для запуска Java-приложений, но не для их разработки. Она включает в себя Java Virtual Machine (JVM), которая интерпретирует скомпилированный Java-код (байт-код) и позволяет приложению выполняться на любой платформе, не зависящей от аппаратного обеспечения, а также набор базовых библиотек классов, необходимых для выполнения приложений.

Основные различия

Назначение: JDK используется для разработки Java-приложений, включая их компиляцию и отладку, тогда как JRE предназначен исключительно для их запуска.
Содержание: JDK включает JRE (то есть все, что нужно для запуска Java-приложений), а также дополнительные инструменты разработки, такие как компилятор и отладчик. JRE включает JVM и библиотеки классов, необходимые для выполнения приложений, но не содержит инструменты разработки.
Использование: Разработчики устанавливают JDK, чтобы иметь возможность разрабатывать и тестировать свои приложения, в то время как конечные пользователи могут установить только JRE для запуска Java-приложений.

Важно отметить, что для запуска Java-приложения на компьютере пользователя достаточно наличия JRE. Однако для полноценной разработки, компиляции и отладки Java-программ необходим JDK.

➡️ Примеры ответов
➡️ Список всех вопросов на Java Developer

🧩 Идущий | 🔐 Собесы | 🔐 Тестовые
Please open Telegram to view this post
VIEW IN TELEGRAM
👍245