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

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

Ir al canal en Telegram

📈 Análisis del canal de Telegram Java | Вопросы собесов

El canal Java | Вопросы собесов (@easy_java_ru) en el segmento lingüístico de Ruso es un actor destacado. Actualmente la comunidad reúne a 11 450 suscriptores, ocupando la posición 10 899 en la categoría Tecnologías y Aplicaciones y el puesto 57 490 en la región Rusia.

📊 Métricas de audiencia y dinámica

Desde su creación el невідомо, el proyecto ha mostrado un crecimiento acelerado, reuniendo a 11 450 suscriptores.

Según los últimos datos del 05 junio, 2026, el canal mantiene una actividad estable. En los últimos 30 días la variación de miembros fue de 20, y en las últimas 24 horas de 6, conservando un alto alcance.

  • Estado de verificación: No verificado
  • Tasa de interacción (ER): El promedio de interacción de la audiencia es 7.92%. Durante las primeras 24 horas tras publicar, el contenido suele obtener 7.61% de reacciones respecto al total de suscriptores.
  • Alcance de las publicaciones: Cada publicación recibe en promedio 907 visualizaciones. En el primer día suele acumular 871 visualizaciones.
  • Reacciones e interacción: La audiencia responde de forma activa: el promedio de reacciones por publicación es 0.
  • Intereses temáticos: El contenido se centra en temas clave como ставь, void, string, строка, static.

📝 Descripción y política de contenido

El autor describe el recurso como un espacio para expresar opiniones subjetivas:
Cайт easyoffer.ru Реклама @easyoffer_adv ВП @easyoffer_vp Тесты t.me/+icUwivvbGOkwNWRi Задачи t.me/+8eqUTboisnkyZjQy Вакансии t.me/+4pspF5nDjgM4MjQy

Gracias a la alta frecuencia de actualizaciones (últimos datos recibidos el 06 junio, 2026), el canal mantiene la vigencia y un amplio alcance. La analítica demuestra que la audiencia interactúa activamente con el contenido, lo que lo convierte en un punto de referencia dentro de la categoría Tecnologías y Aplicaciones.

11 450
Suscriptores
+624 horas
-117 días
+2030 días
Archivo de publicaciones
🤔 Как на Java писать веб-приложение? Веб-приложение на Java – это серверное приложение, которое обрабатывает HTTP-запросы и отправляет ответы клиенту. 🚩Написание веб-приложения на Spring Boot Установка зависимостей (Maven) Создайте pom.xml и добавьте
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <version>3.2.2</version> <!-- Используйте актуальную версию -->
    </dependency>
</dependencies>
Создание основного класса (точка входа)
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class MyWebApp {
    public static void main(String[] args) {
        SpringApplication.run(MyWebApp.class, args);
    }
}
Создание контроллера (обработка HTTP-запросов)**
import org.springframework.web.bind.annotation.*;

@RestController
@RequestMapping("/api")
public class MyController {

    @GetMapping("/hello")
    public String sayHello() {
        return "Привет, это веб-приложение на Java!";
    }
}
Теперь при открытии http://localhost:8080/api/hello сервер вернёт:
Привет, это веб-приложение на Java!
🚩Разработка фронтенда (HTML + Thymeleaf) Если приложение рендерит страницы на сервере, используйте Thymeleaf. Добавьте зависимость в pom.xml
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
Создайте HTML-шаблон (src/main/resources/templates/index.html)
<!DOCTYPE html>
<html>
<head>
    <title>Главная страница</title>
</head>
<body>
    <h1>Привет, <span th:text="${name}"></span>!</h1>
</body>
</html>
Создайте контроллер для отображения страницы
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class WebController {
    @GetMapping("/")
    public String home(Model model) {
        model.addAttribute("name", "Гость");
        return "index"; // Возвращает "index.html"
    }
}
🚩Работа с базой данных (Spring Data JPA + PostgreSQL) Добавьте зависимости в pom.xml
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
    <groupId>org.postgresql</groupId>
    <artifactId>postgresql</artifactId>
</dependency>
Настройте application.properties (подключение к БД)
spring.datasource.url=jdbc:postgresql://localhost:5432/mydb
spring.datasource.username=postgres
spring.datasource.password=secret
spring.jpa.hibernate.ddl-auto=update
Создайте сущность (таблицу в БД)
import jakarta.persistence.*;

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;

    // Геттеры и сеттеры
}
Создайте Repository для работы с БД
import org.springframework.data.jpa.repository.JpaRepository;

public interface UserRepository extends JpaRepository<User, Long> {
}
Контроллер для работы с БД
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController
@RequestMapping("/users")
public class UserController {
    private final UserRepository userRepository;

    public UserController(UserRepository userRepository) {
        this.userRepository = userRepository;
    }

    @GetMapping
    public List<User> getUsers() {
        return userRepository.findAll();
    }

    @PostMapping
    public User addUser(@RequestBody User user) {
        return userRepository.save(user);
    }
}
Запустите приложение:
mvn spring-boot:run
Проверьте API через браузер или Postman
http://localhost:8080/users
Ставь 👍 и забирай 📚 Базу знаний

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

🤔 К какой категории сущности относится Primary Key? Primary Key (первичный ключ) в базах данных относится к категории ограничений (constraints). Это специальное ограничение, которое накладывается на столбец или группу столбцов таблицы, чтобы однозначно идентифицировать каждую строку (запись) в таблице. 🚩Основные свойства Primary Key 🟠Уникальность Значение первичного ключа должно быть уникальным для каждой строки. Это исключает дублирование записей. 🟠Не может быть NULL Столбец (или столбцы), определённый как Primary Key, не допускает значения NULL, так как NULL не может однозначно идентифицировать строку. 🟠Только один Primary Key на таблицу Таблица может иметь только один первичный ключ, но он может состоять из одного столбца (простой ключ) или нескольких (составной ключ). 🚩Зачем нужен Primary Key? Для однозначной идентификации записей в таблице. Для создания связей между таблицами в реляционных базах данных (внешние ключи ссылаются на первичный ключ другой таблицы). Для ускорения поиска и манипуляций с данными за счёт создания индекса на столбец первичного ключа. 🚩Пример использования Primary Key Простой первичный ключ
CREATE TABLE Users (
    user_id INT PRIMARY KEY,
    username VARCHAR(50),
    email VARCHAR(100)
);
Составной первичный ключ
CREATE TABLE Orders (
    order_id INT,
    product_id INT,
    PRIMARY KEY (order_id, product_id)
);
Ставь 👍 и забирай 📚 Базу знаний

🤔 Что такое пропагация (propagation) транзакции? Это определяет, как должна вести себя транзакция при вызове метода внутри другой транзакции: - REQUIRED — использовать текущую или создать новую; - REQUIRES_NEW — всегда новая; - SUPPORTS, NOT_SUPPORTED, MANDATORY, NEVER, NESTED. Используется для управления вложенными операциями, их откатом или фиксацией независимо. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Расскажи про Hash Code & Equals Contract Когда вы переопределяете методы equals() и hashCode(), важно соблюдать контракт, иначе объект может вести себя некорректно в коллекциях (HashMap, HashSet и др.). 🚩Контракт `equals()` Метод equals() определяет, когда два объекта равны. Рефлексивность – x.equals(x) всегда true. Симметричность – x.equals(y) == y.equals(x). Транзитивность – если x.equals(y) и y.equals(z), то x.equals(z). Согласованность – многократные вызовы x.equals(y) дают один и тот же результат. Сравнение с null всегда falsex.equals(null) == false.
class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) return true;  // Проверка на одинаковые ссылки
        if (obj == null || getClass() != obj.getClass()) return false; // Проверка типа
        Person person = (Person) obj;
        return age == person.age && name.equals(person.name); // Сравнение полей
    }
}
🚩Контракт `hashCode()` Метод hashCode() возвращает числовой хеш-код объекта. Он должен соответствовать equals()! Если x.equals(y) == true, то x.hashCode() == y.hashCode(). Если x.hashCode() != y.hashCode(), то x.equals(y) == false (но обратное не всегда верно). Хеш-код должен оставаться неизменным, если объект не изменяется.
@Override
public int hashCode() {
    return Objects.hash(name, age);
}
🚩Почему контракт `equals()` и `hashCode()` важен? В коллекциях, таких как HashSet, HashMap, HashTable, объекты хранятся по хеш-коду. Что будет, если equals() переопределён, но hashCode() – нет?
Set<Person> people = new HashSet<>();
people.add(new Person("Иван", 25));
people.add(new Person("Иван", 25)); // Ожидаем, что не добавится

System.out.println(people.size()); // ❌ Будет 2, а не 1, если `hashCode()` отсутствует!
Правильный вариант (equals() + hashCode())
class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) return true;
        if (obj == null || getClass() != obj.getClass()) return false;
        Person person = (Person) obj;
        return age == person.age && name.equals(person.name);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 Как подключить свою библиотеку в другом проекте? Для подключения своей библиотеки: - собрать её в JAR; - опубликовать в локальный или удалённый репозиторий (например, Maven Central, Nexus, Artifactory); - добавить зависимость в pom.xml или build.gradle другого проекта. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Какой цикл жизни Spring Beans? Каждый бин (компонент) проходит через жизненный цикл, который начинается с его создания и заканчивается уничтожением. Этот цикл включает в себя ряд этапов, на которых он предоставляет различные точки для настройки поведения бина. Вот основные этапы жизненного цикла: 🟠Инстанцирование бина Создает экземпляр бина из класса определения бина. 🟠Заполнение свойств бина Внедряет значения и ссылки на другие бины в свойства текущего бина, используя конфигурацию, заданную в XML, аннотациях или конфигурации. 🟠Вызов методов жизненного цикла BeanNameAware Если бин реализует один из Aware интерфейсов, он вызывает соответствующие методы, передавая экземпляру бина ссылку на контекст, фабрику бинов и т.д. 🟠Post-Processing Bean Перед инициализацией бина, он дает возможность BeanPostProcessor'ам обработать объект. Это может быть использовано для проксирования бинов или для иной предварительной обработки. 🟠Вызов метода инициализации Если для бина определен метод инициализации (через аннотацию @PostConstruct, интерфейс InitializingBean или атрибут init-method в XML-конфигурации), он вызывает его после того, как все свойства бина были установлены. 🟠Готовность к использованию После вызова метода инициализации бин полностью инициализирован и готов к использованию в приложении. 🟠Вызов метода уничтожения Когда контекст приложения закрывается, и бины должны быть уничтожены, он вызывает метод уничтожения для бинов, которые определяют его (через аннотацию @PreDestroy, интерфейс DisposableBean или атрибут destroy-method в XML-конфигурации). Ставь 👍 и забирай 📚 Базу знаний

Зимняя распродажа в MAAG: скидки стали ещё больше Самое время для шопинга: скидки на бестселлеры женской коллекции. ❤️ Верхняя одежда, свитеры, платья, деним, натуральная кожа – все для зимы и переходного сезона. Заходите на maag-fashion.com – ваш незаменимый помощник в создании стильных образов по приятным ценам.✨ Купить #реклама maag-fashion.com О рекламодателе

🤔 Что нравится во Vue? - Простота и гибкость; - Разделение на шаблон/логика/стили в одном файле (.vue); - Сильная поддержка компонентов; - Реактивные данные и computed свойства; - Хорошая поддержка SSR и сборщиков (Vite, Webpack). Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Что такое синхронизация и зачем она нужна? Синхронизация — это механизм, который используется для контроля доступа к общим ресурсам или критическим секциям кода в среде, где несколько потоков или процессов могут одновременно выполняться. Основная цель — обеспечить корректное взаимодействие между потоками, предотвращая одновременное выполнение определённых участков кода, которые могут привести к конфликтам или неконсистентному состоянию данных. 🚩Зачем она нужна 🟠Предотвращение гонки данных (race conditions) Гонка данных возникает, когда два или более потоков одновременно пытаются изменить общие данные, и результат выполнения зависит от того, в каком порядке потоки выполняют операции. Синхронизация помогает управлять доступом к данным таким образом, чтобы обеспечить их целостность. 🟠Обеспечение видимости изменений В многопоточной среде изменения, сделанные одним потоком в общем ресурсе, могут не быть сразу видны другим потокам из-за кэширования данных в процессорах или оптимизаций компилятора. Синхронизация гарантирует, что изменения, сделанные одним потоком, будут корректно видны другим потокам. 🟠Последовательный доступ к ресурсам Некоторые операции или ресурсы требуют последовательного доступа для предотвращения конфликтов или некорректной работы. Например, запись в файл или обновление базы данных должны выполняться последовательно, чтобы избежать наложения данных или повреждения структуры данных. 🚩Как она реализуется 🟠Ключевое слово synchronized Может использоваться для блокировки целого метода или определённого блока кода, обеспечивая монопольный доступ к этому участку кода для одного потока одновременно. 🟠Явные блокировки с использованием классов из пакета java.util.concurrent.locks Предоставляют более гибкие возможности для управления блокировками, включая попытку захвата блокировки без ожидания, захват прерываемых блокировок и блокировки с возможностью повторного входа. 🟠Волатильные переменные (volatile) Обеспечивают видимость изменений переменных между разными потоками, но не контролируют последовательность доступа к переменной. Ставь 👍 и забирай 📚 Базу знаний

Запустите рекламу в телеграм-каналах с Яндекс Директом Перфоманс-реклама теперь в телеграм-каналах ⚡ Яндекс Директ знает, как
Запустите рекламу в телеграм-каналах с Яндекс Директом Перфоманс-реклама теперь в телеграм-каналах ⚡ Яндекс Директ знает, как привлечь целевую аудиторию 💰👌 Попробовать #реклама yandex.ru О рекламодателе

🤔 Что такое хранимые процедуры и какой способ вызова через JDBC? Хранимая процедура — это набор SQL-команд, сохранённых в базе данных. Вызов через JDBC выполняется через CallableStatement, например: CallableStatement cs = connection.prepareCall("{call my_procedure(?)}");. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

📺 База 1000+ реальных собеседований На программиста, тестировщика, аналитика, проджекта и другие IT профы. Есть собесы от ведущих компаний: Сбер, Яндекс, ВТБ, Тинькофф, Озон, Wildberries и т.д. 🎯 Переходи по ссылке и присоединяйся к базе, чтобы прокачать свои шансы на успешное трудоустройство!

🤔 Является ли коллекция HashMap потоком безопасной? Коллекция HashMap не является потокобезопасной. Это означает, что при одновременном доступе к нему из нескольких потоков без должной синхронизации могут возникнуть проблемы, такие как потеря данных, гонки за данные и другие виды состояний гонки. Если один поток изменяет ее структуру (например, добавляя или удаляя элементы), в то время как другой поток итерирует по ней или также пытается внести изменения, результаты могут быть непредсказуемыми. 🟠Collections.synchronizedMap(Map) Оборачивает ее (или любую другую карту) в потокобезопасную обёртку, гарантируя безопасность при доступе из разных потоков. Однако при использовании этого метода важно помнить, что если итерация по коллекции происходит в многопоточной среде, необходимо синхронизировать весь блок итерации на возвращённой карте для предотвращения конкурентных модификаций.
Map<String, String> map = Collections.synchronizedMap(new HashMap<>());    
🟠ConcurrentHashMap Предоставляет потокобезопасную реализацию карты без блокировки всей карты. ConcurrentHashMap разработан для высокой конкуренции и эффективности при доступе из множества потоков, обеспечивая лучшую производительность по сравнению с synchronizedMap. ConcurrentHashMap позволяет одновременно читать данные из карты несколькими потоками без блокировки и записывать данные при минимальной блокировке.
Map<String, String> concurrentMap = new ConcurrentHashMap<>();
Ставь 👍 и забирай 📚 Базу знаний

Инвестиции в апарт-отель в сердце Архыза «Villa Monte» Пассивный доход с окупаемостью 8 лет и доходностью от 2 млн. руб. в го
Инвестиции в апарт-отель в сердце Архыза «Villa Monte» Пассивный доход с окупаемостью 8 лет и доходностью от 2 млн. руб. в год. Апартаменты "под ключ" с профессиональной управляющей компанией. 365 дней круглогодичный поток туристов! Ежегодный прирост тур. потока - 25% Курортная недвижимость востребована и всегда растет в цене. ⚡Получите презентацию с расчетом доходности на сайте! Перейти на сайт #реклама dohodnye-appartamenti.ru О рекламодателе

🤔 Где в обработке исключений может применяться конструкция с finally? Блок finally применяется для освобождения ресурсов, таких как закрытие файлов, потоков или соединений, вне зависимости от того, произошло исключение или нет. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 После какого момента GC понимает, что нужно собирать мусор? Garbage Collector (GC) в Java начинает сборку мусора, когда объекты в памяти больше не используются и не имеют активных ссылок. 🟠Основное правило: объект считается мусором, если нет на него ссылок GC понимает, что объект можно удалить, если на него больше не ссылается ни одна переменная или он стал недостижимым.
class Demo {
    int value;
}

public class Main {
    public static void main(String[] args) {
        Demo obj = new Demo(); // Создан объект в памяти (Heap)
        obj = null; // Теперь на него нет ссылки → GC его удалит
    }
}
🚩Когда GC запускается? 🟠Недостаток памяти (Low Memory) Если в куче (Heap) осталось мало свободной памяти, JVM может запустить GC. 🟠Алгоритмы JVM (GC работает автоматически) GC в Java автоматический, и его запуск зависит от алгоритма сборщика мусора. Некоторые из них: Serial GC (для маленьких программ) Parallel GC (по умолчанию в Java 8) G1 GC (по умолчанию в Java 11+) ZGC, Shenandoah GC (для высоконагруженных систем) 🚩Способы обнаружения "мусора" 🟠Счётчик ссылок (Reference Counting) Устарело, потому что не умеет работать с циклическими ссылками. 🟠Алгоритм "Reachability" (Достижимость) Основной метод, который использует GC в Java. 🟠Алгоритм достижимости (Reachability Analysis) GC начинает с корневых объектов (GC Roots) и проверяет, какие объекты достижимы. Ставь 👍 и забирай 📚 Базу знаний

🤔 Посредством чего можно сделать идентификацию записи в таблице? Для этого используют первичный ключ (Primary Key) — уникальное поле или набор полей. Это может быть AUTO_INCREMENT, UUID или вручную заданное значение. Он позволяет однозначно идентифицировать строку в таблице. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 В чем разница между Spring аннотациями Component, Repository и Service? Все три аннотации используются в Spring для создания бинов, но у каждой есть своё предназначение. 🚩`@Component` – базовая аннотация для бина @Component помечает класс как Spring-бин (компонент). Является универсальной аннотацией. Можно применять к любым классам, которые должны управляться Spring-контейнером.
@Component
public class MyComponent {
    public void doWork() {
        System.out.println("Работа компонента");
    }
}
🚩`@Service` – для бизнес-логики @Service – это специализированный @Component, используемый для сервисных классов (логика приложения). Упрощает понимание кода (показывает, что этот класс содержит бизнес-логику).
@Service
public class UserService {
    public String getUser() {
        return "Пользователь Иван";
    }
}
🚩`@Repository` – для работы с базой данных @Repository – это специализированный @Component для слоя доступа к данным (DAO, Repository). Автоматически перехватывает SQL-исключения (PersistenceExceptionTranslationPostProcessor) и преобразует их в DataAccessException.
@Repository
public class UserRepository {
    public String findUserById(int id) {
        return "Пользователь с ID " + id;
    }
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 Как вызывать static метод интерфейса? Через имя интерфейса: InterfaceName.methodName(). Такие методы не переопределяются и не доступны через объект класса. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний