Java | Вопросы собесов
Cайт easyoffer.ru Реклама @easyoffer_adv ВП @easyoffer_vp Тесты t.me/+icUwivvbGOkwNWRi Задачи t.me/+8eqUTboisnkyZjQy Вакансии t.me/+4pspF5nDjgM4MjQy
Ko'proq ko'rsatish📈 Telegram kanali Java | Вопросы собесов analitikasi
Java | Вопросы собесов (@easy_java_ru) Rus til segmentidagi kanali faol ishtirokchi. Hozirda hamjamiyat 11 454 obunachidan iborat bo'lib, Texnologiyalar & Aralashmalar toifasida 10 891-o'rinni va Rossiya mintaqasida 57 522-o'rinni egallagan.
📊 Auditoriya ko‘rsatkichlari va dinamika
невідомо sanasidan buyon loyiha tez o‘sib, 11 454 obunachiga ega bo‘ldi.
08 Iyun, 2026 dagi oxirgi ma’lumotlarga ko‘ra kanal barqaror faollikka ega. Oxirgi 30 kunda obunachilar soni 11 ga, so‘nggi 24 soatda esa 7 ga o‘zgardi va umumiy qamrov yuqori darajada qolmoqda.
- Tasdiqlash holati: Tasdiqlanmagan
- Jalb etish (ER): Auditoriya o‘rtacha 10.52% darajada jalb etiladi. Nashrdan keyingi dastlabki 24 soatda kontent odatda umumiy obunachilar sonining 7.55% ini tashkil etuvchi reaksiyalarni to‘playdi.
- Post qamrovi: Har bir post o‘rtacha 1 205 marta ko‘riladi; birinchi sutkada odatda 865 ta ko‘rish yig‘iladi.
- Reaksiyalar va o‘zaro ta’sir: Auditoriya faol: har bir postga o‘rtacha 7 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 09 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.
Я, Андрей Борисов, автор ютуб канала по java 16 лет опыт профессиональной разработки на java (A1 Austria Telecom Group, Qulix Systems, SDWORX) Вел 6 HIGH LOAD проектов Основатель школы JavaGuru.by 300+ учеников повысили квалификацию и перешли на современный стек, увеличив доходПоделюсь анализом рынка, на основании опыта проведения 6 потоков по микросервисной архитектуре для повышения квалификации мидлов и 5 групп по трудоустройству мидлом за последний год Сегодня рынок стал жестче и интереснее. Java всё ещё в топе, но условия постоянно меняются. 1) Джунам тяжело, мидлам тесно, сеньорам норм Самая болезненная зона — Junior и слабый Middle: - много кандидатов - собеседования стали глубже, хотят уже system design даже Надо отметить, что прохождение собеседования это отдельный скилл, и, было достаточно случаев, когда ученик с нулевым опытом рисовал 4+ лет и залетал даже на синьорскую позицию, а с грамотным и опытным парнем мучались пол года пока прошел собес. 2) В 2025 году количество вакансий менялось волнообразно - Весной насколько помните было резкое падение количества после 2024 года - В июне-июле рынок ожил, мои ребята неплохо получали тех собесы и большинство устроились во время курса - Август-сентябрь очень мало вакансий, но в октябре стало легче, чуть хуже, но тоже нормально устроились ученики - В конце осени было совсем мало вакансий, до нового года в группе оффер получили 34% группы, остальные продолжили уже после праздников Сбербанк осенью провел оптимизацию сотрудников, довольно много java программистов с опытом вышло на рынок и плюс традиционное затишье к концу года 3) Теперь 4+ - Если в 2024 году резюме с 3+ работало, то в 2025 студенты академий заточенных конкретно на залет в ИТ, стали рисовать 4+ и резюме с 3+ стали плохо привлекать внимание HR - Если в 2025 очень редко были случаи проверки опыта, то к концу 2025 почти в половине случаев просили выгрузку с госуслуг трудовой или фото договоров ИП/ГПХ 4) Минимальный стек для собеса мидлом: - Spring / Spring Boot - микросервисные паттерны и в целом дизайн системы - Kafka/RabbitMQ - Docker + Kubernetes (хотя бы на уровне “понимаю”) - БД: PostgreSQL, Redis, Elastic - понимание CI/CD Рынок сместился от кодера к инженеру. И это главное отличие. 5) Что реально повышает шансы в 2026 - Подтверждение опыта - Реактивный стек - Опыт с high-load - Опыт в финтех - Опыт с продом: кубер, ci/cd, мониторинг, saga - Понимание архитектуры - Я лично пока не встречал ученика даже без реального опыта, который бы получив твердую мидловую квалификацию: шарит в кубере, экосистеме спринг вглубь и архитектуре и при этом не смог утроиться за пол года. Порог входа высокий, зато по сравнению с языками с низким порогом входа, при наличии реального уровня, трудоустройство гарантированно. ИТОГ: - ЗП не уменьшается. - Java в топе среди языков. - Устроиться сложно, надо учить) - IT профессии постепенно переходят в разряд обычных из хайповых, где хорошие спецы много получают, а на старте без опыта очень трудно устроиться. Здесь видео по: микросервисным паттернам SAGA и OUTBOX Apache Kafka Канал для повышения квалификации java Отзывы о курсе Профессиональная разработка микросервисов https://javaguru.by/ ❤️ Core -> Enterprise -> Bootcamp -> Микросервисы | Трудоустройство | РЕАКТИВНЫЙ СТЕК | ИТ-СТАРТАП-РЕТРИТ
class UserRepositoryStub implements UserRepository {
@Override
public User findById(Long id) {
return new User(id, "Иван"); // Просто возвращает статичные данные
}
}
🚩Mock (Макет)
Mock – это объект, который имитирует поведение реального объекта и позволяет проверять вызовы методов (сколько раз был вызван, с какими аргументами и т. д.).
UserRepository userRepository = mock(UserRepository.class);
when(userRepository.findById(1L)).thenReturn(new User(1L, "Иван"));
User user = userRepository.findById(1L);
verify(userRepository, times(1)).findById(1L); // Проверяем, что метод был вызван 1 раз
Ставь 👍 и забирай 📚 Базу знанийТаблицаA), а также соответствующие строки из правой таблицы (ТаблицаB). Если совпадение в правой таблице не найдено, результат будет содержать NULL на месте столбцов правой таблицы.
🚩RIGHT JOIN (или RIGHT OUTER JOIN)
Работает аналогично LEFT JOIN, но возвращает все строки из правой таблицы (ТаблицаB), а также соответствующие строки из левой таблицы (ТаблицаA). Если совпадение в левой таблице не найдено, результат будет содержать NULL на месте столбцов левой таблицы.
INNER JOIN используется для получения строк с совпадениями в обеих таблицах.
LEFT JOIN возвращает все строки из левой таблицы и соответствующие строки из правой таблицы; если соответствий нет, вместо столбцов правой таблицы будут NULL.
RIGHT JOIN возвращает все строки из правой таблицы и соответствующие строки из левой таблицы; если соответствий нет, вместо столбцов левой таблицы будут NULL.
Ставь 👍 и забирай 📚 Базу знаний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) и проверяет, какие объекты достижимы.
Ставь 👍 и забирай 📚 Базу знаний @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)
Проверяет, как система работает в условиях сверхвысокой нагрузки.
Ставь 👍 и забирай 📚 Базу знанийintern() в классе String используется для оптимизации памяти.
Он добавляет строку в String Pool и возвращает её ссылку, если строка уже там есть.
🚩Как работает `intern()`?
Без intern() – строки создаются в Heap (куче)
String s1 = new String("Hello"); // В куче (Heap)
String s2 = new String("Hello");
System.out.println(s1 == s2); // false (разные объекты)
С intern() – строки хранятся в String Pool
String s1 = new String("Hello").intern();
String s2 = new String("Hello").intern();
System.out.println(s1 == s2); // true (одна строка в String Pool)
🚩Что такое `String Pool`?
Это специальная область памяти, где хранятся уникальные строковые литералы.
Все строковые литералы ("Hello") по умолчанию хранятся в String Pool.
String s1 = "Hello"; // В String Pool
String s2 = "Hello"; // Ссылается на тот же объект
System.out.println(s1 == s2); // true
🚩Когда использовать `intern()`?
Когда у вас много одинаковых строк в памяти (например, имена, идентификаторы).
Для экономии памяти, если строки часто дублируются.
В парсинге JSON, XML – одни и те же строки могут повторяться тысячи раз.
List<String> names = new ArrayList<>();
for (int i = 0; i < 100000; i++) {
names.add(("User" + (i % 100)).intern()); // Используем String Pool
}
Ставь 👍 и забирай 📚 Базу знанийforEach позволяет компактно и удобно итерировать по элементам коллекций.
List<String> names = Arrays.asList("Alice", "Bob", "Charlie");
names.forEach(name -> System.out.println(name));
🟠Фильтрация и преобразование коллекций
С использованием Stream API и лямбда-выражений можно легко фильтровать, сортировать и преобразовывать коллекции.
List<String> names = Arrays.asList("Alice", "Bob", "Charlie", "David");
List<String> filteredNames = names.stream()
.filter(name -> name.startsWith("A"))
.collect(Collectors.toList());
filteredNames.forEach(System.out::println); // Вывод: Alice
🟠Сортировка коллекций
Лямбда-выражения упрощают сортировку коллекций с использованием метода sort.
List<String> names = Arrays.asList("Alice", "Bob", "Charlie");
names.sort((name1, name2) -> name1.compareTo(name2));
names.forEach(System.out::println);
🟠Использование функциональных интерфейсов
Лямбда-выражения широко используются с функциональными интерфейсами, такими как Predicate, Function, Consumer и Supplier.
// Predicate
Predicate<String> startsWithA = s -> s.startsWith("A");
boolean result = startsWithA.test("Alice"); // true
// Function
Function<String, Integer> lengthFunction = s -> s.length();
int length = lengthFunction.apply("Hello"); // 5
// Consumer
Consumer<String> printConsumer = s -> System.out.println(s);
printConsumer.accept("Hello, World!"); // Вывод: Hello, World!
// Supplier
Supplier<String> stringSupplier = () -> "Hello, Supplier!";
String suppliedString = stringSupplier.get();
System.out.println(suppliedString); // Вывод: Hello, Supplier!
🟠Параллельные вычисления
Лямбда-выражения с использованием параллельных потоков позволяют легко выполнять параллельные вычисления.
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
int sum = numbers.parallelStream()
.mapToInt(Integer::intValue)
.sum();
System.out.println("Sum: " + sum); // Вывод: Sum: 15
🚩Пример использования в реальном проекте
Предположим, у нас есть список сотрудников, и мы хотим отфильтровать и отсортировать их по имени.
import java.util.*;
import java.util.stream.Collectors;
class Employee {
private String name;
private int age;
public Employee(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
@Override
public String toString() {
return "Employee{name='" + name + "', age=" + age + '}';
}
}
public class LambdaExample {
public static void main(String[] args) {
List<Employee> employees = Arrays.asList(
new Employee("Alice", 30),
new Employee("Bob", 25),
new Employee("Charlie", 35),
new Employee("David", 28)
);
// Фильтрация и сортировка сотрудников по имени
List<Employee> filteredAndSorted = employees.stream()
.filter(e -> e.getAge() > 27)
.sorted(Comparator.comparing(Employee::getName))
.collect(Collectors.toList());
filteredAndSorted.forEach(System.out::println);
}
}
Ставь 👍 и забирай 📚 Базу знаний
@RequiredArgsConstructor
@Component
public class OutboxScheduler {
private final OutboxService outboxService;
@Scheduled(fixedDelay = 10_000)
public void run() {
outboxService.processAll();
}
}
Сервис:
@Transactional
public void processAll() {
outboxRepository
.selectForProcessing()
.forEach(this::process);
}
private void process(OutboxRecord outboxRecord) {
try {
recordProcessor.process(outboxRecord);
outboxRepository.delete(outboxRecord);
log.info("Processed data: {}", outboxRecord.getPayload());
} catch (Exception e) {
log.warn("Failed to process data", e);
}
}
Минусы такого подхода:
1) От задержки в обработке никуда не деться
2) Самописное решение - усложнение поддержки проекта
3) Нагрузка на базу
4) Трудности, которые надо решать разруливая доступ к outbox табличке когда есть несколько реплик микра
Но и с этими недостатками можно поработать и с большего убрать!
Как?
Kafka Connect, Debezium, Kafka Streams
Здесь ВИДЕО разбор OUTBOX на youtube и rutube
А здесь SAGA
Как освоить микросервисную архитекруру на практике!
https://javaguru.by❤️
Core -> Enterprise -> Bootcamp -> Микросервисы | Трудоустройство | РЕАКТИВНЫЙ СТЕК | ИТ-СТАРТАП-РЕТРИТ | СВОЕ ДЕЛО
Endi mavjud! Telegram Tadqiqoti 2025 — yilning asosiy insaytlari 
