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

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

Kanalga Telegram’da o‘tish

📈 Telegram kanali Java | Вопросы собесов analitikasi

Java | Вопросы собесов (@easy_java_ru) Rus til segmentidagi kanali faol ishtirokchi. Hozirda hamjamiyat 11 450 obunachidan iborat bo'lib, Texnologiyalar & Aralashmalar toifasida 10 899-o'rinni va Rossiya mintaqasida 57 490-o'rinni egallagan.

📊 Auditoriya ko‘rsatkichlari va dinamika

невідомо sanasidan buyon loyiha tez o‘sib, 11 450 obunachiga ega bo‘ldi.

05 Iyun, 2026 dagi oxirgi ma’lumotlarga ko‘ra kanal barqaror faollikka ega. Oxirgi 30 kunda obunachilar soni 20 ga, so‘nggi 24 soatda esa 6 ga o‘zgardi va umumiy qamrov yuqori darajada qolmoqda.

  • Tasdiqlash holati: Tasdiqlanmagan
  • Jalb etish (ER): Auditoriya o‘rtacha 7.92% darajada jalb etiladi. Nashrdan keyingi dastlabki 24 soatda kontent odatda umumiy obunachilar sonining 7.61% ini tashkil etuvchi reaksiyalarni to‘playdi.
  • Post qamrovi: Har bir post o‘rtacha 907 marta ko‘riladi; birinchi sutkada odatda 871 ta ko‘rish yig‘iladi.
  • Reaksiyalar va o‘zaro ta’sir: Auditoriya faol: har bir postga o‘rtacha 0 ta reaksiya keladi.
  • Tematik yo‘nalishlar: Kontent ставь, void, string, строка, static kabi asosiy mavzularga jamlangan.

📝 Tavsif va kontent siyosati

Muallif resursni shaxsiy fikrni ifoda etish maydoni sifatida ta’riflaydi:
Cайт easyoffer.ru Реклама @easyoffer_adv ВП @easyoffer_vp Тесты t.me/+icUwivvbGOkwNWRi Задачи t.me/+8eqUTboisnkyZjQy Вакансии t.me/+4pspF5nDjgM4MjQy

Yuqori yangilanish chastotasi (oxirgi ma’lumot 06 Iyun, 2026 da olingan) sababli kanal doimo dolzarb va katta qamrovli bo‘lib qoladi. Analitika auditoriya kontent bilan faol hamkorlik qilishini, uni Texnologiyalar & Aralashmalar toifasidagi muhim ta’sir nuqtasiga aylantirishini ko‘rsatadi.

11 450
Obunachilar
+624 soatlar
-117 kunlar
+2030 kunlar
Postlar arxiv
"Ты че, дурак?" – базовая реакция сеньора на тех, кто покупает IT курсы Дело в том, что онлайн школы создают инкубаторных айт
"Ты че, дурак?" – базовая реакция сеньора на тех, кто покупает IT курсы Дело в том, что онлайн школы создают инкубаторных айтишников, которые в реальных условиях попросту зависнут. Трушные ребята учатся на жизненных каналах для айтишников. Вот топ-5 от тимлида из Сбера: ⚙️ Технолоджия – для тех, кто хочет быть в курсе новостей в айти 🧠 Ai-чница – способы превратить нейросети в заработок $$$ 💻 ИИ тебя заменит! – тенденции айти рынка в связке с нейросетями 4️⃣ Войти в IT – тонны бесплатного обучения для прогеров 😄 IT индус – сборник айти мемов

🤔 Назови 3 любых метода которые приходят от Object? В Java класс Object является базовым родителем для всех классов. Это значит, что любые классы в Java неявно наследуются от него, если явно не указан другой родительский класс. От класса Object каждый класс в Java получает набор методов. 🟠toString() Что делает: Возвращает строковое представление объекта. Зачем нужен: Этот метод часто используется для вывода объектов в человекочитаемом виде, особенно для отладки или логирования. Как работает по умолчанию: Возвращает строку, включающую имя класса и хэш-код объекта (неинтуитивно для человека). Как переопределить: Обычно переопределяют, чтобы возвращать содержимое полей объекта в удобном формате.
class Person {
    String name;
    int age;

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

    @Override
    public String toString() {
        return "Person{name='" + name + "', age=" + age + "}";
    }
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person("Анна", 25);
        System.out.println(person.toString()); // Person{name='Анна', age=25}
    }
}
🟠equals(Object obj) Что делает: Проверяет, равны ли два объекта. Зачем нужен: Сравнивать два объекта на логическое равенство (например, у вас есть два объекта типа Person и вы хотите понять, одинаковые ли у них значения полей). Как работает по умолчанию: Сравнивает ссылки объектов (т.е. проверяет, указывают ли переменные на один и тот же объект в памяти). Как переопределить: Переопределяют, чтобы сравнивать содержимое объектов (их поля).
class Person {
    String name;
    int age;

    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);
    }
}

public class Main {
    public static void main(String[] args) {
        Person person1 = new Person("Анна", 25);
        Person person2 = new Person("Анна", 25);
        System.out.println(person1.equals(person2)); // true
    }
}
🟠hashCode() Что делает: Возвращает числовой хэш-код объекта. Зачем нужен: Используется для оптимизации работы хэш-структур данных, таких как HashMap, HashSet. Как работает по умолчанию: Генерирует уникальный хэш-код на основе местоположения объекта в памяти (что не всегда полезно). Как переопределить: Если переопределён метод equals, обязательно переопределите hashCode, чтобы объекты, которые равны по equals, имели одинаковый хэш-код.
class Person {
    String name;
    int age;

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

    @Override
    public int hashCode() {
        return name.hashCode() + age * 31; // Простая, но эффективная формула
    }
}

public class Main {
    public static void main(String[] args) {
        Person person = new Person("Анна", 25);
        System.out.println(person.hashCode()); // Например, 2084975
    }
}
Ставь 👍 и забирай 📚 Базу знаний

Айтишники, это вам — в телеграм есть комьюнити по каждому направлению в IT Там есть буквально всё: чаты для общения, тонны ма
Айтишники, это вам — в телеграм есть комьюнити по каждому направлению в IT Там есть буквально всё: чаты для общения, тонны материала(книги, курсы, ресурсы и гайды), свежие новости и конечно же мемы Выбирайте своё направление: 💩 Frontend 🐍 Python 🐧 Linux 👩‍💻 С/С++ 👩‍💻 C# 🤔 Хакинг & ИБ 📱 GitHub 🖥 SQL 👩‍💻 Сисадмин 🤟 DevOps ⚙️ Backend 🖥 Data Science 🧑‍💻 Java 🐞 Тестирование 🖥 PM / PdM 👩‍💻 GameDev 🧑‍💻 Golang 🤵‍♂️ IT-Митапы 🧑‍💻 PHP 💻 WebDev 🖥 Моб. Dev 🖥Анали.(SA&BA) 👩‍💻 Дизайн 🖥 Нейросети 💛 1C 🤓 Книги IT ➡️ Сохраняйте в закладки

Бесплатный курс по дизайну: веб, графический и UX/UI Научись создавать дизайн сайтов и приложений, инфографику для карточек н
Бесплатный курс по дизайну: веб, графический и UX/UI Научись создавать дизайн сайтов и приложений, инфографику для карточек на маркетплейсах и работать в Figma! Студенты курса в среднем зарабатывают от 68 000 ₽ уже во время обучения💰 Этот курс для тебя, если ты: ✅ мечтаешь о новой профессии в digital, но не знаешь, с чего начать; ✅ чувствуешь, что хочешь большего — свободы, самореализации, творчества; ✅ полный новичок и хочешь систему, а не хаос; ✅ хочешь начать зарабатывать удалённо. Зарегистрироваться #реклама 16+ ydaev.ru О рекламодателе

🤔 Инструменты CI/CD? Популярные инструменты CI/CD (Continuous Integration / Continuous Deployment) включают Jenkins, GitLab CI, GitHub Actions, CircleCI, Travis CI, ArgoCD, Spinnaker, Bamboo. Они автоматизируют процессы сборки, тестирования и развертывания приложений. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 В чем разница между request mapping и put mapping? Главное отличие: @RequestMapping – универсальная аннотация, поддерживающая все HTTP-методы (GET, POST, PUT, DELETE и т. д.). @PutMapping – специализированная аннотация для PUT-запросов. 🚩`@RequestMapping` – универсальная аннотация Можно использовать для любого HTTP-метода (GET, POST, PUT, DELETE). Необходимо явно указывать method = RequestMethod.PUT, если нужен PUT.
@RestController
@RequestMapping("/users")
public class UserController {

    @RequestMapping(value = "/{id}", method = RequestMethod.PUT)
    public String updateUser(@PathVariable Long id, @RequestBody String userData) {
        return "Пользователь с ID " + id + " обновлён!";
    }
}
🚩`@PutMapping` – упрощённый способ для `PUT`-запросов Это специализированная аннотация, эквивалентная @RequestMapping(method = RequestMethod.PUT).
@RestController
@RequestMapping("/users")
public class UserController {

    @PutMapping("/{id}")
    public String updateUser(@PathVariable Long id, @RequestBody String userData) {
        return "Пользователь с ID " + id + " обновлён!";
    }
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 В чём преимущество Hibernate перед JDBC? Hibernate избавляет от необходимости вручную писать SQL-запросы и управлять соединениями. Он автоматически маппит объекты Java на таблицы базы данных (ORM), управляет кэшированием, транзакциями, ленивой загрузкой (lazy loading) и миграцией схем. Это ускоряет разработку, упрощает тестирование и уменьшает количество шаблонного кода. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Расскажи про транзитивность Транзитивность — это математическое и логическое свойство отношений, означающее, что если A связано с B, а B связано с C, то A связано с C. 🚩Транзитивность в отношении эквивалентности (`equals`) Согласно контракту метода equals(), он должен быть транзитивным
class Person {
    String name;

    Person(String name) {
        this.name = name;
    }

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

public class Main {
    public static void main(String[] args) {
        Person p1 = new Person("Иван");
        Person p2 = new Person("Иван");
        Person p3 = new Person("Иван");

        System.out.println(p1.equals(p2)); // true
        System.out.println(p2.equals(p3)); // true
        System.out.println(p1.equals(p3)); // true (транзитивность)
    }
}
🚩Транзитивность в сравнении (`compareTo` из `Comparable`) Метод compareTo() должен соблюдать транзитивность:
class Student implements Comparable<Student> {
    int age;

    Student(int age) {
        this.age = age;
    }

    @Override
    public int compareTo(Student other) {
        return Integer.compare(this.age, other.age);
    }
}

public class Main {
    public static void main(String[] args) {
        Student s1 = new Student(25);
        Student s2 = new Student(20);
        Student s3 = new Student(15);

        System.out.println(s1.compareTo(s2)); // > 0 (s1 > s2)
        System.out.println(s2.compareTo(s3)); // > 0 (s2 > s3)
        System.out.println(s1.compareTo(s3)); // > 0 (s1 > s3) (транзитивность)
    }
}
🚩Транзитивность в наследовании (`extends` / `implements`) В Java классы могут наследоваться транзитивно
class Animal {}
class Mammal extends Animal {}
class Dog extends Mammal {}
Ставь 👍 и забирай 📚 Базу знаний

Онлайн-трансляция SOC Forum 2025. Регистрация открыта! SOC Forum — одно из крупнейших событий в сфере ИБ, которое проходит в рамках Российской недели кибербезопасности. ✅ Здесь встречаются эксперты, представители бизнеса и госструктур, чтобы обсудить ключевые вызовы отрасли. Событие, которое нельзя пропустить. Для тех, кто не может присутствовать лично, будет запущена онлайн-трансляция: 👌 Переключайтесь между залами. 👌 Выбирайте только актуальные для вас выступления. 👌 Задавайте вопросы спикерам в прямом эфире. 👌 Участвуйте в интерактивах. И все это не выходя из дома. Зарегистрируйтесь, и мы напомним о старте трансляции и пришлем ссылку, чтобы вы ничего не пропустили. Узнать больше #реклама 16+ registration.forumsoc.ru О рекламодателе

🤔 Какая конфигурация выполнится приоритетней: XML, Java или Annotation? Приоритет выполнения зависит от загрузки контекста, но в случае конфликта конфигураций аннотации и Java-конфигурация имеют больший приоритет над XML. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 В чём заключается разница между методами start() и run()? 🚩`start()` – создаёт новый поток Метод start() создаёт новый поток и вызывает run() внутри него.
class MyThread extends Thread {
    @Override
    public void run() {
        System.out.println("Работает поток: " + Thread.currentThread().getName());
    }
}

public class Main {
    public static void main(String[] args) {
        MyThread thread = new MyThread();
        thread.start(); // Запускаем новый поток

        System.out.println("Работает поток: " + Thread.currentThread().getName());
    }
}
Вывод (разные потоки работают параллельно)
Работает поток: main
Работает поток: Thread-0
🚩`run()` – выполняется в ТЕКУЩЕМ потоке (без создания нового) Если вызвать run() напрямую, код просто выполнится как обычный метод, а не в новом потоке.
public class Main {
    public static void main(String[] args) {
        MyThread thread = new MyThread();
        thread.run(); // ❌ Ошибка! Работает в главном потоке

        System.out.println("Работает поток: " + Thread.currentThread().getName());
    }
}
Вывод (run() работает в главном потоке, а не в новом)
Работает поток: main
Работает поток: main
Ставь 👍 и забирай 📚 Базу знаний

Быстрый старт в кибербез: с нуля до первой работы Ищешь перспективную профессию с быстрым ростом зарплаты? Кибербезопасность
Быстрый старт в кибербез: с нуля до первой работы Ищешь перспективную профессию с быстрым ростом зарплаты? Кибербезопасность — востребованная сфера с острой нехваткой специалистов. Здесь реально выйти на доход от 70 000 уже за полгода. Даже без опыта и образования в ИТ. С чего начать и как построить карьеру, расскажут эксперты Солара на вебинаре 14 ноября в 19:00: ✅ Какие профессии доступны новичкам без опыта и как быстро их освоить. ✅ Как найти свою первую работу. ✅ Какие ошибки допускают новички в начале пути. Всем участникам подарим пошаговый план по саморазвитию и быстрому старту в кибербезопасность. Присоединяйтесь! Зарегистрироваться #реклама 16+ rt-solar.ru О рекламодателе

🤔 Что такое StringJoiner? Это класс, позволяющий постепенно собирать строку с заданным разделителем, префиксом и суффиксом. Используется для создания строк, состоящих из элементов, разделённых символами (например, CSV, JSON-массивы). Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

Repost from Идущий к IT
🔥 Записал видос "Как за 3 минуты настроить Автоотклики на вакансии HeadHunter" больше не придется заниматься этой унылой рут
🔥 Записал видос "Как за 3 минуты настроить Автоотклики на вакансии HeadHunter" больше не придется заниматься этой унылой рутиной 📺 Видео: https://youtu.be/G_FOwEGPwlw

🤔 Как устроена память JVM? JVM (Java Virtual Machine) управляет памятью приложения и делит её на несколько областей. 🟠Heap (Куча) – область для объектов Здесь хранятся ВСЕ объекты и массивы, созданные через new. Управляется Garbage Collector (GC) 🟠Stack (Стек) – область для методов и переменных Локальные переменные (int, double, String – если не new) Ссылки на объекты в Heap Вызовы методов (кадры стека)
public class StackExample {
    public static void main(String[] args) {
        int a = 5;
        int b = sum(a, 10);
    }

    public static int sum(int x, int y) {
        return x + y;
    }
}
🟠Metaspace – метаданные классов Хранит информацию о загруженных классах (названия, методы, поля, байт-код). При загрузке нового класса ClassLoader выделяет память в Metaspace. В Java 8 заменил устаревший PermGen.
while (true) {
    ClassLoader loader = new MyClassLoader();
    Class<?> clazz = loader.loadClass("MyDynamicClass");
}
🟠Program Counter (PC Register) Хранит адрес текущей инструкции, выполняемой потоком. У каждого потока свой PC Register. Работает как указатель в машинном коде. 🟠Native Method Stack Хранит данные, связанные с вызовами нативных методов (JNI – Java Native Interface). Если Java вызывает C++-код, информация о вызове хранится здесь.
public class NativeExample {
    public native void callCMethod();
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 Какие основные три метода есть у Servlet и в чем их задача? init() вызывается при инициализации и подготавливает сервлет. service() обрабатывает входящие запросы. destroy() вызывается при завершении работы сервлета и очищает ресурсы. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Что такое Appender в log4j? Это компонент, который отвечает за отправку логов в различные места назначения, такие как файлы, консоль, базы данных, сетевые сокеты или даже удаленные серверы. Каждый Appender реализует конкретный способ обработки и хранения логов. 🚩Зачем нужен Appender? Appender позволяет гибко управлять тем, куда и как сохраняются логи. В зависимости от требований приложения, вы можете: Писать логи в файл. Выводить их в консоль. Отправлять их в удалённые хранилища или базы данных. 🚩Основные виды Appender в Log4j 🟠ConsoleAppender Логи выводятся в консоль. Полезно для разработки и отладки.
     <Appender type="Console" name="ConsoleAppender">
         <Target>System.out</Target>
     </Appender>
     
🟠FileAppender Логи записываются в файл. Используется для длительного хранения логов.
     <Appender type="File" name="FileAppender">
         <FileName>logs/app.log</FileName>
         <Append>true</Append>
     </Appender>
     
🟠RollingFileAppender Расширение FileAppender с возможностью ротации логов (ограничение размера файла, создание новых файлов при переполнении).
     <Appender type="RollingFile" name="RollingFileAppender">
         <FileName>logs/app.log</FileName>
         <FilePattern>logs/app-%d{yyyy-MM-dd}.log</FilePattern>
         <Policies>
             <SizeBasedTriggeringPolicy size="10MB"/>
         </Policies>
     </Appender>
     
🟠DailyRollingFileAppender Логи записываются в файл, который ротационно создаётся каждый день.
     <Appender type="DailyRollingFile" name="DailyRollingAppender">
         <FileName>logs/app.log</FileName>
         <DatePattern>.yyyy-MM-dd</DatePattern>
     </Appender>
     
🟠SocketAppender Отправляет логи через сеть (TCP или UDP). Используется для централизованного логирования. 🟠JDBCAppender Записывает логи в базу данных.
     <Appender type="JDBC" name="JDBCAppender">
         <ConnectionSource>
             <DriverManagerConnectionSource>
                 <DriverClass>org.h2.Driver</DriverClass>
                 <Url>jdbc:h2:mem:logdb</Url>
                 <User>sa</User>
             </DriverManagerConnectionSource>
         </ConnectionSource>
         <TableName>log_table</TableName>
     </Appender>
     
🚩Конфигурация Appender в log4j2 Вот пример конфигурации с использованием нескольких Appender XML-конфигурация
<Configuration>
    <Appenders>
        <Console name="ConsoleAppender" target="SYSTEM_OUT">
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level: %msg%n"/>
        </Console>
        <File name="FileAppender" fileName="logs/app.log">
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level: %msg%n"/>
        </File>
    </Appenders>
    <Loggers>
        <Root level="info">
            <AppenderRef ref="ConsoleAppender"/>
            <AppenderRef ref="FileAppender"/>
        </Root>
    </Loggers>
</Configuration>
Java-конфигурация
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

public class Main {
    private static final Logger logger = LogManager.getLogger(Main.class);

    public static void main(String[] args) {
        logger.info("This is an info log");
        logger.error("This is an error log");
    }
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 Как из одного сервлета вызвать другой сервлет? 1. С помощью объекта RequestDispatcher, вызвав его методы forward() или include(). 2. Через отправку запроса с использованием sendRedirect() для внешнего перенаправления. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Чем полезны неизменяемые (Immutable) объекты в Java? Неизменяемые (immutable) объекты не могут быть изменены после создания. Если нужно изменить данные – создаётся новый объект. 🚩Почему неизменяемые объекты полезны? 🟠Потокобезопасность (Thread Safety) Неизменяемые объекты можно безопасно использовать в многопоточной среде – их не нужно синхронизировать.
String message = "Hello";
String newMessage = message.replace("H", "J");

System.out.println(message); // Hello
System.out.println(newMessage); // Jello
🟠Отсутствие неожиданных изменений (безопасность данных) Если объект неизменяемый, его нельзя случайно изменить.
class BankAccount {
    private final String accountNumber;

    public BankAccount(String accountNumber) {
        this.accountNumber = accountNumber;
    }

    public String getAccountNumber() {
        return accountNumber;
    }
}
🟠Упрощает отладку и поддержку кода Изменяемые объекты могут менять состояние в неожиданный момент.
List<String> list = new ArrayList<>();
list.add("Java");

modifyList(list); // Метод может изменить список!

System.out.println(list); // Ожидаем ["Java"], но может быть что угодно!
🟠Можно использовать в качестве ключей в `HashMap` и `HashSet` Хешкод неизменяемого объекта не изменится, а значит, он корректно работает в HashMap.
Map<String, String> map = new HashMap<>();
map.put("key", "value");

System.out.println(map.get("key")); // Всегда "value", так как String неизменяемый
🟠Совместимость с кэшем (например, в Hibernate, Spring) Неизменяемые объекты можно безопасно кешировать, так как они не меняются. 🚩Как создать неизменяемый класс? Все поля private final. Нет сеттеров. Если есть массивы или списки – копируем их перед возвратом.
final class Person {
    private final String name;
    private final int age;

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

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 Как у класса заполнить атрибуты? Атрибуты класса (поля) можно заполнить: - через конструктор; - через сеттеры; - через аннотации Spring (@Autowired, @Value); - через внедрение зависимостей или маппинг объектов. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний