Java Backend | YeaHub
933 subscribers
238 photos
28 videos
3 files
415 links
Теория, подготовка к интервью и курсы для Java разработчиков

YeaHub — это платформа для IT-специалистов, объединяющая обучение, карьерный рост, развитие и сообщество единомышленников.

Платформа: https://yeahub.ru

Для связи: @ruslan_kuyanets
Download Telegram
#Собес #docker #java #deploy
🤔 Как осуществляется контейнеризация Java-приложений с помощью Docker?

💬 Кратко:

Java-приложение можно контейнеризовать, создав Dockerfile, в котором указывается базовый образ с JDK или JRE, копируется jar-файл и прописывается команда запуска. Это позволяет запускать приложение изолированно, независимо от настроек окружения. Основные шаги — сборка jar-файла, написание Dockerfile и сборка образа с помощью команды docker build.

📌 Полный разбор + примеры использования — на платформе:
👉 Перейти к разбору

📣 Хочешь получать больше таких разборов?
Подпишись на наш главный канал
1
ArrayList vs LinkedList: что выбрать на практике? 🎯

Привет, коллеги! 👋

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

Первый на очереди — вечный спор: ArrayList vs LinkedList.

Ключевые различия

ArrayList:
- Основан на массиве
- Быстрый доступ по индексу O(1)
- Медленная вставка/удаление в середине O(n)
- Оптимизирован под чтение

LinkedList:
- Двусвязный список
- Медленный доступ по индексу O(n)
- Быстрая вставка/удаление в середине O(1)
- Оптимизирован под модификации

Практический пример

// ArrayList - быстрое чтение
List<String> arrayList = new ArrayList<>();
arrayList.get(1000); // Мгновенно

// LinkedList - быстрое изменение
List<String> linkedList = new LinkedList<>();
linkedList.add(0, "new element"); // Быстро


Когда что использовать?

ArrayList:
- Частое чтение по индексу
- Итерация по элементам
- Предсказуемый размер данных

LinkedList:
- Частые вставки/удаления в начале/середине
- Реализация очередей (Queue/Deque)
- Динамически изменяемые данные

Бенчмарк на реальных операциях

// Вставка в начало
arrayList.add(0, "new"); // O(n) - медленно
linkedList.addFirst("new"); // O(1) - быстро

// Доступ по индексу
arrayList.get(1000); // O(1) - быстро
linkedList.get(1000); // O(n) - медленно


Выводы

В 95% случаев выбирайте ArrayList — он эффективнее по памяти и быстрее для большинства операций.

LinkedList используйте только для специфических сценариев с частыми модификациями в середине списка.

Следующий в серии — HashMap vs ConcurrentHashMap! Ждите скоро

А вы часто используете LinkedList в своих проектах? Делитесь опытом в комментариях! 👇

#java #interview #arraylist #linkedlist #collections
5👍1🔥1
Многопоточность в Java: synchronized, volatile и Lock 🛡️ (Часть 2)

Привет, коллеги! 👋

Вторая часть про многопоточность. Сегодня разбираем механизмы синхронизации.

synchronized методы

class SafeCounter {
private int count = 0;

public synchronized void increment() {
count++; // Теперь безопасно
}

public synchronized int getCount() {
return count;
}
}


synchronized блоки

class Resource {
private final Object lock = new Object();

public void doWork() {
synchronized(lock) {
// критическая секция
}
}
}


volatile переменные

class TaskProcessor {
private volatile boolean running = true;

public void stop() {
running = false; // Видимость между потоками
}

public void process() {
while (running) {
// работа
}
}
}


ReentrantLock

class LockedCounter {
private final ReentrantLock lock = new ReentrantLock();
private int count = 0;

public void increment() {
lock.lock();
try {
count++;
} finally {
lock.unlock();
}
}
}


Сравнение подходов

synchronized:
- Простота использования
- Автоматическое управление
- Встроено в язык

ReentrantLock:
- Гибкость (tryLock, fair lock)
- Явное управление
- Требует аккуратности

В третьей части разберем Concurrent коллекции, пулы потоков и современные подходы!

Какие механизмы синхронизации используете вы? 👇

#java #interview #multithreading #synchronized
1🔥1
#Собес #java #collections #multithreading

🤔 Middle+ Java Backend разработчик в компанию Госуслуги

Техническое собеседование. Лето 2024. Вилка: 300-350к. Опыт в резюме: 4+ года. В конце собеседования были задачи на структуры данных, оптимизацию запросов и работу с БД.

💬 Вопросы:

- Как логировать время выполнения методов в бинах Spring унифицированно?

- Как централизованно обрабатывать исключения в REST-контроллерах?

- Как работает @Transactional и что происходит, если метод без аннотации вызывает метод с аннотацией?

- Как спроектировать доступ к балансам пользователей из разных потоков, чтобы операции были консистентны?

- Какие механизмы синхронизации можно использовать, кроме synchronized и Atomic?

👉 Все вопросы из этого собеседования (17)

📣 Хочешь больше собесов?
Подпишись на наш главный канал
1
Spring Boot: автоконфигурация и REST API (Часть 2)

Привет, коллеги! 👋

Вторая часть про Spring. Сегодня — Spring Boot и создание REST API.

Что такое Spring Boot?

Spring Boot упрощает настройку Spring-приложений:
- Автоконфигурация
- Встроенные серверы (Tomcat, Jetty)
- Starter-зависимости
- Готовые production-фичи

Создание приложения

Структура проекта:
src/main/java/
└── com/example/demo/
├── DemoApplication.java
├── controller/
├── service/
└── repository/


Основной класс:
@SpringBootApplication
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}


Создание REST контроллера

@RestController
@RequestMapping("/api/users")
public class UserController {

private final UserService userService;

public UserController(UserService userService) {
this.userService = userService;
}

@GetMapping
public List<User> getAllUsers() {
return userService.findAll();
}

@GetMapping("/{id}")
public User getUserById(@PathVariable Long id) {
return userService.findById(id);
}

@PostMapping
@ResponseStatus(HttpStatus.CREATED)
public User createUser(@RequestBody User user) {
return userService.create(user);
}
}


Spring Boot Starters

<!-- В pom.xml -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>


Конфигурация через application.yml

# application.yml
server:
port: 8081

spring:
datasource:
url: jdbc:postgresql://localhost:5432/mydb
username: user
password: pass

jpa:
hibernate:
ddl-auto: update
show-sql: true


Spring Boot Actuator

# Мониторинг приложения
management:
endpoints:
web:
exposure:
include: health,info,metrics


В третьей части разберем Spring Data JPA, транзакции и тестирование!

Какой ваш любимый Spring Boot starter? 👇

#springboot #restapi #java #spring
2🔥1🤝1
#Собес #java #microservices #monolith

🤔 Middle Java Backend-разработчик в компанию IT-smart.

Техническое собеседование. Осень 2024. Просил 250к+. Опыт в резюме 3 года. Сначала были вопросы по опыту работы, воркфлоу, гитфлоу

💬 Вопросы:

- Разница между Spring и Spring Boot

- Что такое Bean?

- Что такое распределённый кэш?

- Когда использовать локальный кэш, а когда распределённый?

- Когда нужно использовать кэширование?

👉 Все вопросы из этого собеседования (23)

📣 Хочешь больше собесов?
Подпишись на наш главный канал
#Собес #java #acid #transaction

🤔 Middle Java Backend developer в компанию Сбер

Техническое собеседование. Лето 2025. Вилка: 240к+. Опыт в резюме: 3.9 года. Проект: разработка высоконагруженных систем для Сбербанк Онлайн

💬 Вопросы:

- Какой жизненный цикл Spring Beans?

- Для чего используются BeanPostProcessor и BeanFactoryPostProcessor?

- Как достать бин из ApplicationContext?

- Стандартные способы управления потоками (ExecutorService, Future)

- Зачем нужен volatile? Как он обеспечивает видимость изменений?

👉 Все вопросы из этого собеседования (25)

📣 Хочешь больше собесов?
Подпишись на наш главный канал
#Собес #jvm #java #kotlin

🤔 Middle Java Backend разработчик в Сбер

Техническое собеседование. Лето 2025. Опыт в резюме: 4.2. года. Вилка: 250-280к. Был лайвкодинг, задачи на SQL.

💬 Вопросы:

- Как реализовать оптимистичную и пессимистичную блокировки в Spring?

- Как работает аннотация @Transactional в Spring?

- Как выявлять и устранять утечки памяти в Java-приложениях?

- Какие инструменты вы используете для мониторинга памяти и производительности?

- Какие преимущества Kotlin перед Java вы знаете?

👉 Все вопросы из этого собеседования (21)

📣 Хочешь больше собесов?
Подпишись на наш главный канал