Java Portal | Программирование
11.8K subscribers
889 photos
67 videos
31 files
715 links
Присоединяйтесь к нашему каналу и погрузитесь в мир для Java-разработчика

Связь: @devmangx

РКН: https://clck.ru/3H4WUg
加入频道
Различия между List, Set и Map в Java — как раз то, что часто спрашивают на интервью

1. List представляет собой упорядоченную коллекцию элементов, в которой допускаются дубликаты. Элементы сохраняют порядок вставки, как, например, в ArrayList. Доступ к элементам осуществляется по индексу, например list.get(0). Основные методы: add(), get(), remove(), set().

Часто используемые реализации — ArrayList и LinkedList. List может содержать несколько значений null.

Потокобезопасность не обеспечивается по умолчанию, но можно использовать Collections.synchronizedList(). Сценарий применения — когда важен порядок элементов и допускаются дубликаты. Для сортировки можно использовать Collections.sort(). Производительность: быстрое чтение у ArrayList, быстрая вставка у LinkedList. Поддерживается работа с потоками, например list.stream().

2. Set — это неупорядоченная коллекция уникальных элементов. Порядок не гарантируется (например, в HashSet). Доступ осуществляется через итерацию.

Основные методы: add(), contains(), remove(). Часто используемые реализации — HashSet, LinkedHashSet, TreeSet. Set может содержать только один элемент null, как в HashSet. Потокобезопасность отсутствует. Применяется, когда важна уникальность элементов.

Сортировка поддерживается в TreeSet, где элементы хранятся отсортированными. Производительность: быстрые операции в HashSet. Потоки поддерживаются (stream()).

3. Map — это коллекция пар ключ-значение. Ключи должны быть уникальными, значения — нет.

Ключи могут быть неупорядоченными (HashMap), отсортированными (TreeMap) или упорядоченными по порядку вставки (LinkedHashMap). Доступ осуществляется по ключу, например map.get(key). Основные методы: put(), get(), remove(), containsKey(). Типичные реализации — HashMap, LinkedHashMap, TreeMap, ConcurrentHashMap.

Разрешён один null-ключ и несколько null-значений (например, в HashMap). Потокобезопасность отсутствует в HashMap, но есть в ConcurrentHashMap. Применяется, когда данные организованы в формате ключ-значение. TreeMap поддерживает сортировку по ключам. Производительность: быстрый доступ у HashMap, отсортированный доступ у TreeMap. Поддержка потоков осуществляется через map.entrySet().stream().

👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM
Потокобезопасные неизменяемые данные с использованием Java Records:

Классы record в Java обеспечивают встроенную неизменяемость, что делает их идеальными для безопасного обмена данными между потоками. В сочетании с ExecutorService они упрощают конкурентное программирование ❤️

👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM
Примитивные типы данных

Мини-шпаргалка для новичков и тех, кто повторяет основы

🔸byte — 1 байт
Диапазон: -128 до 127

🔸short — 2 байта
Диапазон: -32,768 до 32,767

🔸int — 4 байта
Диапазон: -2,147,483,648 до 2,147,483,647

🔸long — 8 байт
Диапазон: ±9 квинтиллионов (±2^63)

🔸float — 4 байта
Точность: ~7 знаков после запятой

🔸double — 8 байт
Точность: ~15 знаков после запятой

🔸char — 2 байта
Хранит 1 Unicode-символ

🔸 boolean — ~1 бит (зависит от JVM)
Значения: true / false

👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM
Взаимоблокировка (deadlock) в Java

Взаимоблокировка возникает, когда два потока удерживают блокировки и одновременно ожидают освобождения друг друга, что приводит к зависанию программы. Такая ситуация труднообнаружима и становится кошмаром в масштабных приложениях 😨

👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM
Java остаётся одним из самых популярных языков уже больше двух десятилетий.

Банковские системы, e-commerce платформы, Android-приложения и многое другое, всё это можно писать на Java.

В этом курсе ты изучишь основы Java: от переменных и циклов до объектно-ориентированного программирования (OOP). 😊

👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM
Продвинутый уровень конкуррентности, неблокирующие структуры данных

Если вы пишете многопоточные приложения с высокой нагрузкой, стоит обратить внимание на lock-free программирование. Использование атомарных переменных позволяет обходиться без блокировок, это помогает избежать блокировок и повысить производительность при параллельном доступе к данным

👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM
Масштабирование Java-приложений

Масштабируемость — это способность Java-приложения справляться с увеличением нагрузки (больше пользователей, данных или операций) без потери производительности и надежности. Экосистема Java с её мощными фреймворками и библиотеками предоставляет инструменты для построения масштабируемых систем.

Ключевые стратегии масштабирования Java-приложений

1) Модульная архитектура и микросервисы

Разделяйте монолит: разбивайте приложение на небольшие независимые модули или микросервисы. Каждый сервис можно разрабатывать, деплоить и масштабировать независимо.

🔹Преимущества: масштабируемость отдельных компонентов, изоляция отказов, ускорение разработки.

2) Горизонтальное и вертикальное масштабирование

🔹Горизонтальное масштабирование — добавление серверов/инстансов для распределения нагрузки (например, AWS ELB или Nginx).
🔹Вертикальное масштабирование — увеличение ресурсов на одном сервере (CPU, RAM).

Пример: Развертывание нескольких stateless-сервисов на Spring Boot за балансировщиком, хранение сессий в Redis.

3) Оптимизация базы данных

🔹Пул подключений — используйте HikariCP для эффективного управления соединениями.
🔹Кэширование — внедряйте Redis или Ehcache для сокращения повторяющихся запросов.
🔹Шардирование и репликация — делите данные между БД или используйте реплики для высокой доступности.

Пример на 2 фото

4) Асинхронная и событийно-ориентированная обработка

🔹ExecutorService — управление фоновыми задачами через пулы потоков.
🔹Очереди сообщений — Kafka или RabbitMQ для декуплинга логики и повышения пропускной способности.
🔹Реактивное программирование — Project Reactor или RxJava для неблокирующих, событийных приложений.

Пример на 3 фото

5) Балансировка нагрузки

🔹Распределение запросов — с помощью балансировщиков предотвращайте перегрузку одного инстанса.

Пример: Nginx или AWS ELB для маршрутизации API-запросов к нескольким backend-инстансам Java.

6) Надежность и устойчивость

🔹Отказоустойчивость и избыточность — проектируйте систему с учетом отказов, применяйте авто-масштабирование и резервные ресурсы.
🔹Мониторинг и алерты — используйте Prometheus, ELK Stack и др. для отслеживания метрик и раннего выявления проблем.

Чеклист лучших практик

> Проектируйте stateless-сервисы для простоты горизонтального масштабирования.
> Используйте API для взаимодействия между модулями/сервисами.
> Регулярно мониторьте и анализируйте производительность.
> Реализуйте безопасность на каждом уровне: авторизация, шифрование, сканирование уязвимостей.
> Проектируйте с учетом роста и изменений.

👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
Универсальная обёртка для API-ответов

Дженерики позволяют возвращать типобезопасные и переиспользуемые форматы ответов. Вот как создать обобщённую обёртку ApiResponse<T> для любого payload-а API.

👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM
Разница между ассоциацией, агрегацией и композицией в Java

Определение

↳ Ассоциация: Общее отношение между двумя объектами

↳ Агрегация: Отношение «имеет», при котором дочерний объект может существовать независимо

↳ Композиция: Отношение «часть», при котором дочерний объект не может существовать без родительского

Тип

↳ Ассоциация: Слабо связанное отношение

↳ Агрегация: Ослабленная форма ассоциации (частный случай ассоциации)

↳ Композиция: Усиленная форма ассоциации

Зависимость

↳ Ассоциация: Объекты независимы

↳ Агрегация: Дочерний объект может пережить родительский

↳ Композиция: Жизненный цикл дочернего объекта зависит от родительского

Владение

↳ Ассоциация: Отсутствует владение

↳ Агрегация: Разделённое владение

↳ Композиция: Исключительное владение

Жизненный цикл

↳ Ассоциация: У обоих объектов собственный жизненный цикл

↳ Агрегация: Родитель и потомок могут иметь разные жизненные циклы

↳ Композиция: Жизненный цикл дочернего объекта строго привязан к родительскому

Пример из реальной жизни

↳ Ассоциация: Студент <—> Университет (могут существовать независимо)

↳ Агрегация: Кафедра <—> Университет (могут существовать раздельно)

↳ Композиция: Сердце <—> Человек (не может существовать без человека)

Пример в Java

↳ Ассоциация: Класс A содержит ссылку на класс B

↳ Агрегация: Класс School содержит список объектов Student

↳ Композиция: Класс House содержит объекты Room (при удалении House удаляются и Room)

👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM
Пример выше демонстрирует, как с помощью дженериков можно создать типобезопасный и переиспользуемый процессор данных, который работает с коллекциями объектов, в данном случае, с сотрудниками (Employee).

Основные моменты:

> DataProcessor<T> — обобщённый класс, хранящий список элементов типа T и предоставляющий метод getMax(...), который возвращает максимум по заданному компаратору.
> Employee реализует Comparable<Employee> и переопределяет метод compareTo, чтобы сравнивать сотрудников по зарплате.
> В main() создаются объекты сотрудников и добавляются в DataProcessor<Employee>, после чего находится сотрудник с максимальной зарплатой.

Вывод программы:

Highest paid: Bob ($75000.0)


👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM
Защита вашего приложения с помощью Spring Security и OAuth2 Login.

Публичный доступ разрешён к / и /login, все остальные эндпоинты требуют аутентификации.

Полное руководство читайте здесь: тык

👉 Java Portal
Please open Telegram to view this post
VIEW IN TELEGRAM