en
Feedback
Java | Вопросы собесов

Java | Вопросы собесов

Open in Telegram

📈 Analytical overview of Telegram channel Java | Вопросы собесов

Channel Java | Вопросы собесов (@easy_java_ru) in the Russian language segment is an active participant. Currently, the community unites 11 450 subscribers, ranking 10 899 in the Technologies & Applications category and 57 490 in the Russia region.

📊 Audience metrics and dynamics

Since its creation on невідомо, the project has demonstrated rapid growth, gathering an audience of 11 450 subscribers.

According to the latest data from 05 June, 2026, the channel demonstrates stable activity. Although there has been a change in the number of participants by 20 over the last 30 days and by 6 over the last 24 hours, overall reach remains high.

  • Verification status: Not verified
  • Engagement rate (ER): The average audience engagement rate is 7.92%. Within the first 24 hours after publication, content typically collects 7.61% reactions from the total number of subscribers.
  • Post reach: On average, each post receives 907 views. Within the first day, a publication typically gains 871 views.
  • Reactions and interaction: The audience actively supports content: the average number of reactions per post is 0.
  • Thematic interests: Content is focused on key topics such as ставь, void, string, строка, static.

📝 Description and content policy

The author describes the resource as a platform for expressing subjective opinions:
Cайт easyoffer.ru Реклама @easyoffer_adv ВП @easyoffer_vp Тесты t.me/+icUwivvbGOkwNWRi Задачи t.me/+8eqUTboisnkyZjQy Вакансии t.me/+4pspF5nDjgM4MjQy

Thanks to the high frequency of updates (latest data received on 06 June, 2026), the channel maintains relevance and a high level of publication reach. Analytics show that the audience actively interacts with content, making it an important point of influence in the Technologies & Applications category.

11 450
Subscribers
+624 hours
-117 days
+2030 days
Posts Archive
🤔 Какая коллекция реализует дисциплину обслуживания FIFO? FIFO (First-In, First-Out) – это принцип обработки данных: "первым вошёл – первым вышел". 🟠Коллекции, реализующие FIFO Пример работы FIFO с Queue
import java.util.*;

public class FifoExample {
    public static void main(String[] args) {
        Queue<String> queue = new LinkedList<>(); // Можно заменить на ArrayDeque

        queue.add("Первый");
        queue.add("Второй");
        queue.add("Третий");

        System.out.println(queue.poll()); // Первый
        System.out.println(queue.poll()); // Второй
        System.out.println(queue.poll()); // Третий
    }
}
🟠Разница `poll()`, `remove()` и `peek()`
Queue<Integer> queue = new LinkedList<>();
queue.add(10);
System.out.println(queue.peek());  // 10 (но не удаляет)
System.out.println(queue.poll());  // 10 (удаляет)
System.out.println(queue.poll());  // null (очередь пуста)
Ставь 👍 и забирай 📚 Базу знаний

🤔 В чем отличия GenericServlet и HttpServlet? 1. GenericServlet: общий класс для всех сервлетов, не зависящих от HTTP-протокола. 2. HttpServlet: специализированный класс для работы с HTTP-протоколом, предоставляющий методы для обработки GET, POST, PUT и других запросов. 3. GenericServlet подходит для общих задач, а HttpServlet оптимизирован для веб-приложений. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 В чем разница между Statement и PreparedStatement? Это два интерфейса в JDBC, которые используются для выполнения SQL-запросов к базе данных. Основные различия между ними касаются производительности, безопасности и удобства использования. 🚩Statement Statement используется для выполнения простых SQL-запросов. Запросы формируются и передаются в базу данных в виде строки. Подходит для простых запросов. Не оптимизирован для повторного выполнения. Каждый раз, когда запрос передается в базу данных, он компилируется и выполняется заново. Уязвим к SQL-инъекциям. Поскольку запрос формируется путем конкатенации строк, злоумышленники могут внедрять вредоносный SQL-код.
Statement stmt = connection.createStatement();
String query = "SELECT * FROM employees WHERE department = 'HR'";
ResultSet rs = stmt.executeQuery(query);

while (rs.next()) {
    int id = rs.getInt("id");
    String name = rs.getString("name");
    System.out.println("ID: " + id + ", Name: " + name);
}
stmt.close();
🟠PreparedStatement PreparedStatement используется для выполнения предварительно скомпилированных SQL-запросов. Это позволяет повысить производительность и безопасность. Оптимизирован для повторного выполнения. Запрос компилируется только один раз, а затем может многократно выполняться с разными параметрами, что повышает производительность. Защита от SQL-инъекций. Использует параметризованные запросы, которые помогают избежать уязвимостей, связанных с SQL-инъекциями. Удобство работы с параметрами. Позволяет устанавливать значения параметров с использованием методов setInt(), setString() и других.
String query = "SELECT * FROM employees WHERE department = ?";
PreparedStatement pstmt = connection.prepareStatement(query);
pstmt.setString(1, "HR");
ResultSet rs = pstmt.executeQuery();

while (rs.next()) {
    int id = rs.getInt("id");
    String name = rs.getString("name");
    System.out.println("ID: " + id + ", Name: " + name);
}
pstmt.close();
🚩Основные различия 🟠Производительность Statement: Каждый запрос компилируется заново, что снижает производительность при многократном выполнении одного и того же запроса. PreparedStatement: Запрос компилируется один раз и может многократно выполняться с разными параметрами, что повышает производительность. 🟠Безопасность Statement: Уязвим к SQL-инъекциям, поскольку запросы формируются путем конкатенации строк. PreparedStatement: Использует параметризованные запросы, что защищает от SQL-инъекций. 🟠Удобство использования Statement: Подходит для простых, одноразовых запросов. PreparedStatement: Удобен для многократного выполнения запросов с разными параметрами. 🟠Типы запросов Оба интерфейса могут выполнять запросы типа SELECT, INSERT, UPDATE, DELETE, но PreparedStatement более удобен для запросов с параметрами. Ставь 👍 и забирай 📚 Базу знаний

🤔 Какие промежуточные методы работы со стримами есть? - map(), flatMap() и их примитивные аналоги; - filter(); - distinct(); - sorted(); - peek() (для отладки); - limit(), skip(). Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Как остановить поток? Остановить поток в Java можно несколькими способами, но важно помнить, что принудительная остановка потока – плохая практика. Java предлагает безопасные методы управления потоком, чтобы избежать неожиданных ошибок и некорректного поведения программы. 🚩Плохие способы (НЕ рекомендуется) Раньше использовался метод Thread.stop(), но он был устаревшим и удалённым из-за того, что мог оставить программу в неконсистентном состоянии.
Thread thread = new Thread(() -> {
    while (true) {
        System.out.println("Работаю...");
    }
});

thread.start();
thread.stop(); // ОПАСНО! Может привести к некорректному завершению работы.
🚩Флаг завершения работы (рекомендуемый способ) Самый безопасный способ – это использование флага (volatile boolean).
class MyTask implements Runnable {
    private volatile boolean running = true;

    public void run() {
        while (running) {
            System.out.println("Работаю...");
            try {
                Thread.sleep(500);
            } catch (InterruptedException e) {
                Thread.currentThread().interrupt(); // Важно восстанавливать флаг прерывания
            }
        }
        System.out.println("Поток остановлен.");
    }

    public void stop() {
        running = false;
    }
}

public class Main {
    public static void main(String[] args) throws InterruptedException {
        MyTask task = new MyTask();
        Thread thread = new Thread(task);
        thread.start();

        Thread.sleep(2000);
        task.stop(); // Корректно останавливаем поток
    }
}
🚩Прерывание потока (`interrupt()`) Этот способ удобен для потоков, которые ждут (sleep(), wait(), join()), потому что прерывание выбрасывает InterruptedException.
class MyTask implements Runnable {
    public void run() {
        try {
            while (!Thread.currentThread().isInterrupted()) {
                System.out.println("Работаю...");
                Thread.sleep(500);
            }
        } catch (InterruptedException e) {
            System.out.println("Поток прерван.");
        }
    }
}

public class Main {
    public static void main(String[] args) throws InterruptedException {
        Thread thread = new Thread(new MyTask());
        thread.start();

        Thread.sleep(2000);
        thread.interrupt(); // Прерывание потока
    }
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 В чём идея Autoboxing и Unboxing? Autoboxing — это автоматическое преобразование примитива в объект-обёртку. Unboxing — обратное преобразование объекта-обёртки в примитив. Это удобно при работе с коллекциями и дженериками. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Что такое сигнатура? Сигнатура метода – это его уникальная идентификация в классе. Она включает: Имя метода Список параметров (их типы и порядок)
class Example {
    void print(String text) {}   // Сигнатура: print(String)
    void print(int number) {}    // Сигнатура: print(int)
    int print(String text, int number) { return 0; } // Сигнатура: print(String, int)
}
🚩Почему сигнатура важна? 🟠Перегрузка методов (Method Overloading) В одном классе можно создавать методы с одинаковыми именами, но разными сигнатурами.
class MathUtils {
    int sum(int a, int b) { return a + b; }     // sum(int, int)
    double sum(double a, double b) { return a + b; } // sum(double, double)
}
🟠Переопределение методов (Method Overriding) При переопределении метода (в наследовании) сигнатура ДОЛЖНА быть такой же.
class Parent {
    void show() {} // Сигнатура: show()
}

class Child extends Parent {
    @Override
    void show() {} // ✅ Сигнатура совпадает, корректное переопределение
}
🚩Ошибки, связанные с сигнатурой Ошибка: Возвращаемый тип НЕ влияет на сигнатуру
class Test {
    int method(int x) { return x; } 
    double method(int x) { return x; } // Ошибка! Сигнатура совпадает
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 Как хранил данные в проектах? Использовались подходы: - Реляционные БД (PostgreSQL, MySQL) — для структурированных данных, бизнес-логики. - NoSQL (Redis, MongoDB) — для кэша, документов, логов. - Файловое хранилище (S3, диск) — для медиафайлов, бэкапов. - Room/SQLite — для хранения данных локально на Android. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Чем отличаются Web server и Application server? 🟠Web Server (веб-сервер) обрабатывает HTTP-запросы и отдает статический контент (HTML, CSS, JS, изображения). 🟠Application Server (сервер приложений) запускает бизнес-логику приложения, выполняет обработку данных и работает с базой данных. 🚩Web Server (веб-сервер) Принимает HTTP-запросы от браузера. Отдает статические файлы (HTML, CSS, JS, картинки). Может перенаправлять запросы к Application Server. Apache HTTP Server Nginx Microsoft IIS Допустим, пользователь открывает сайт example.com/index.html: Браузер отправляет HTTP-запрос:
GET /index.html HTTP/1.1
Host: example.com
Веб-сервер (например, Nginx) получает запрос и отправляет браузеру файл index.html. Web Server НЕ обрабатывает логику приложения, он просто отправляет файлы клиенту. 🚩Application Server (сервер приложений) Обрабатывает динамические запросы (например, авторизацию, платежи, работу с БД). Выполняет Java-код (Servlet, EJB, Spring, Hibernate). Может генерировать HTML-страницы на сервере (JSP, Thymeleaf). Управляет транзакциями и соединениями с базой данных. Tomcat (самый популярный в мире Java-сервер) WildFly (JBoss) GlassFish WebLogic, WebSphere Допустим, пользователь заходит на example.com/login: Браузер отправляет HTTP-запрос:
   POST /login HTTP/1.1
   Host: example.com
Ставь 👍 и забирай 📚 Базу знаний

Новогодняя коллекция KUSMI TEA Погрузитесь в новогоднее волшебство — путешествуйте сквозь время и страны вместе с неизменным спутником - пером Жюля Верна! Каждая страница — открытие, каждый глоток — новая страна на карте ваших ощущений. Новогодний чай и адвент-календарь от KUSMI уже в Москве! Узнать больше #реклама tea-france.com О рекламодателе

🤔 Каким образом реализованы методы hashCode() и equals() в классе Object? - equals() по умолчанию — сравнение по ссылке (один и тот же объект); - hashCode() — возвращает уникальный числовой идентификатор, который может зависеть от адреса в памяти (если не переопределён). Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Какие виды тестов знаешь? В программировании существует множество видов тестирования, которые можно разделить на категории по уровню тестирования, методам выполнения и целям. Вот основные виды: 🚩По уровню тестирования 🟠Модульное тестирование (Unit Testing) Тестирование отдельных методов или классов. Цель: Проверить работу минимальных компонентов программы. Инструменты: JUnit, TestNG.
  @Test
  public void testAddition() {
      assertEquals(5, Calculator.add(2, 3));
  }
  
🟠Интеграционное тестирование (Integration Testing) Тестирование взаимодействия между модулями. Цель: Убедиться, что модули правильно работают вместе. Пример: Проверка взаимодействия сервиса и базы данных. Инструменты: Spring Test, Apache Camel Test. 🟠Системное тестирование (System Testing) Проверка всей системы как единого целого. Цель: Убедиться, что все компоненты работают вместе и система соответствует требованиям. 🟠Приемочное тестирование (Acceptance Testing) Проводится с участием клиента или конечных пользователей. Цель: Убедиться, что система удовлетворяет бизнес-требованиям. 🚩По методам выполнения 🟠Ручное тестирование (Manual Testing) Тесты выполняются вручную. Цель: Найти ошибки, которые может не уловить автоматизация. Пример: Тестировщик вручную проверяет пользовательский интерфейс. 🟠Автоматизированное тестирование (Automated Testing) Тесты выполняются автоматически с использованием скриптов и инструментов. Цель: Снизить время и затраты на повторяющиеся тесты. Инструменты: Selenium, JUnit, Appium. 🚩По целям тестирования 🟠Функциональное тестирование Проверяет, что функции системы работают как ожидалось. Цель: Убедиться в соответствии требованиям. Инструменты: Selenium, Postman. 🟠Нефункциональное тестирование Тестирование производительности (Performance Testing): Проверяет скорость, отклик и стабильность. Инструменты: JMeter, Gatling. Тестирование безопасности (Security Testing): Проверяет защиту системы. Инструменты: OWASP ZAP, Burp Suite. Тестирование удобства использования (Usability Testing): Проверяет интерфейс на удобство для пользователя. 🚩По типам тестирования 🟠Smoke Testing Быстрая проверка работоспособности ключевых функций. Цель: Убедиться, что основные функции работают, прежде чем углубляться в тесты. 🟠Регрессионное тестирование Проверяет, что новые изменения не сломали старую функциональность. Цель: Убедиться, что баги, исправленные ранее, не повторились. 🟠Тестирование черного ящика (Black Box Testing) Проверяет систему без знаний о внутреннем устройстве. Цель: Оценить функциональность с точки зрения пользователя. 🟠Тестирование белого ящика (White Box Testing) Проверяет систему с учетом внутренней структуры кода. Цель: Оценить корректность логики программы. 🚩Специальные виды тестирования 🟠A/B тестирование Проверяет, какая версия системы лучше (например, два варианта интерфейса). Цель: Повысить пользовательский опыт. 🟠Тестирование нагрузки (Load Testing) Проверяет, как система работает под большой нагрузкой. Инструменты: Apache JMeter. 🟠Тестирование на отказоустойчивость (Stress Testing) Проверяет, как система работает в условиях сверхвысокой нагрузки. Ставь 👍 и забирай 📚 Базу знаний

🤔 Что такое внедрение зависимости? Внедрение зависимости (Dependency Injection) — это передача объекта (зависимости) другому объекту извне, а не создание его внутри. Это снижает связанность и улучшает тестируемость кода. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Чем отличается обычный объект от Bean? В Spring термин Bean (бин) означает объект, управляемый Spring-контейнером. 🟠Обычный объект (Java POJO) Создаётся вручную, Spring о нём ничего не знает
class Car {
    void drive() {
        System.out.println("Машина едет...");
    }
}

public class Main {
    public static void main(String[] args) {
        Car car = new Car(); // Создаём объект вручную
        car.drive();
    }
}
🟠Spring Bean (управляемый объект) Spring создаёт и управляет бином через аннотации.
import org.springframework.stereotype.Component;

@Component  // Сообщает Spring, что этот класс - Bean
class Car {
    void drive() {
        System.out.println("Spring-машина едет...");
    }
}
Теперь объект создаётся Spring-контейнером
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class Main {
    public static void main(String[] args) {
        ApplicationContext context = new AnnotationConfigApplicationContext(AppConfig.class);
        Car car = context.getBean(Car.class); // Получаем Bean из Spring-контейнера
        car.drive();
    }
}
Ставь 👍 и забирай 📚 Базу знаний

Неделя бесплатных уроков китайского языка с 19.01 ✨Приглашаем к нам на огненные уроки по китайскому языку всех желающих! Неде
Неделя бесплатных уроков китайского языка с 19.01 ✨Приглашаем к нам на огненные уроки по китайскому языку всех желающих! Неделя бесплатных уроков и лекций продлится с 19 по 25 января 2026г. Хотите поехать в Китай? Учиться в китайском вузе? Пройти стажировку в Шанхае или Пекине? Работать с китайцами? Вам точно к нам! Все расскажем, покажем, а вы потрогаете – китайские учебники, ваши записи иероглифов в тетради. На вкус и цвет уроки разные. Занятия проводятся онлайн. ⚡Количество мест ограничено! Запишитесь прямо сейчас! Записаться #реклама 16+ finskiy-razgovornyy-klub.timepad.ru О рекламодателе

🤔 Почему throws в сигнатуре метода — это плохо? Указание throws: - навязывает обработку исключения вызывающей стороне. - Усложняет цепочку вызовов — чем глубже стек, тем больше мест, где нужно писать throws. - Приводит к засорению кода, особенно если исключение часто не критичное. Тем не менее, throws уместен, если исключение действительно важно для внешнего API и требует осознанной обработки. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Что должно быть если объект equals нал? Метод equals() в Java предназначен для проверки равенства двух объектов. Если объект, переданный в метод equals(), равен null, метод должен возвращать `false`, так как объект не может быть равен null по определению. Рассмотрим этот случай более подробно. 🚩Почему важно обрабатывать `null` в `equals()`? 🟠Контракт метода `equals()` Согласно спецификации Java, метод equals() должен возвращать false, если объект, переданный в метод, равен null. Это необходимо для корректного сравнения объектов. Симметричность: Если a.equals(b) возвращает true, то b.equals(a) также должно возвращать true. Для null: Вызов x.equals(null) всегда должен возвращать false. 🟠Предотвращение `NullPointerException` Если метод equals() не проверяет, является ли объект null, попытка доступа к его полям или методам вызовет NullPointerException. 🚩Как правильно реализовать метод `equals()`? Вот стандартный способ реализации метода equals()
@Override
public boolean equals(Object obj) {
    // Проверяем, равен ли объект null
    if (obj == null) {
        return false;
    }
    
    // Проверяем, является ли объект тем же самым
    if (this == obj) {
        return true;
    }

    // Проверяем, принадлежит ли объект тому же классу
    if (getClass() != obj.getClass()) {
        return false;
    }

    // Приводим объект к текущему типу
    MyClass other = (MyClass) obj;

    // Сравниваем необходимые поля
    return this.field.equals(other.field);
}
🚩Что происходит, если игнорировать проверку `null`? Если вы не проверяете null, код вроде следующего приведет к ошибке
MyClass obj1 = new MyClass("Hello");
MyClass obj2 = null;

System.out.println(obj1.equals(obj2)); // Если нет проверки null -> NullPointerException
Пример с проверкой null
class MyClass {
    private String value;

    public MyClass(String value) {
        this.value = value;
    }

    @Override
    public boolean equals(Object obj) {
        if (obj == null) {
            return false;
        }
        if (this == obj) {
            return true;
        }
        if (getClass() != obj.getClass()) {
            return false;
        }
        MyClass other = (MyClass) obj;
        return value.equals(other.value);
    }
}

public class Main {
    public static void main(String[] args) {
        MyClass obj1 = new MyClass("Hello");
        MyClass obj2 = null;

        System.out.println(obj1.equals(obj2)); // false
    }
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 Что такое Spring Data Specification? Specification — это способ построения динамических, типобезопасных условий запросов. Используется вместе с JpaSpecificationExecutor, позволяет собирать запросы гибко и модульно, особенно при работе с фильтрами и множеством условий. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Какая структура данных в коллекции List? В Java интерфейс List представляет упорядоченную коллекцию элементов, допускающую дубликаты. В зависимости от конкретной реализации (ArrayList, LinkedList, Vector), используется разная структура данных. 🚩Основные реализации `List` и их структуры данных 🟠ArrayList Динамический массив Структура данных: массив Быстрая индексация O(1), но медленное удаление/вставка в середину O(n).
List<String> list = new ArrayList<>();
🟠LinkedList Двусвязный список Структура данных: двусвязный список Быстрое добавление/удаление элементов O(1), но медленный доступ по индексу O(n).
List<String> list = new LinkedList<>();
🟠Vector Динамический массив (синхронизирован) Структура данных: массив (как ArrayList), но с синхронизацией. Устарел, используется редко из-за synchronized методов (медленнее ArrayList).
List<String> list = new Vector<>();
Ставь 👍 и забирай 📚 Базу знаний

🤔 Есть ли противопоказания к использованию индексов? Да, есть. Индексы — полезны, но не всегда. Противопоказания: - Частые изменения данных (вставка, удаление, обновление) — индексы замедляют операции. - Избыточные индексы — занимают много памяти. - На маленьких таблицах — скан всей таблицы быстрее, чем обращение к индексу. - Низкая селективность поля — индекс малоэффективен (например, поле со значениями "муж"/"жен"). Индекс — это компромисс между скоростью чтения и затратами на поддержку. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний