Библиотека джависта | Java, Spring, Maven, Hibernate
24.9K subscribers
1.86K photos
38 videos
42 files
2.64K links
Все самое полезное для Java-разработчика в одном канале.

Список наших каналов: https://yangx.top/proglibrary/9197

Обратная связь: @proglibrary_feedback_bot

По рекламе: @proglib_adv

РКН: https://gosuslugi.ru/snet/67a5bbda1b17b35b6c1a55c4
加入频道
JPA vs Hibernate: в чём разница?

JPA (Java Persistence API) — это стандарт, который описывает общие принципы работы с объектно-реляционным маппингом (ORM) в Java. Он определяет набор интерфейсов и аннотаций, позволяя разработчикам работать с базами данных на уровне объектов, абстрагируясь от конкретных реализаций. Благодаря этому JPA обеспечивает переносимость кода между различными ORM-фреймворками, такими как Hibernate, EclipseLink, OpenJPA и другие.

Hibernate, в свою очередь, является одной из наиболее популярных реализаций JPA и предоставляет множество дополнительных возможностей, которые выходят за рамки базовой спецификации. Среди этих функций — кэширование второго уровня и гибкие механизмы создания запросов, собственные расширения и оптимизации, которые могут сделать работу с данными более эффективной и удобной.

Выбор между JPA как стандарта и Hibernate как реализации зависит от специфики проекта. Если вам важно сохранить возможность замены ORM-фреймворка или переноса кода между различными проектами без необходимости внесения существенных изменений, JPA будет оптимальным вариантом. Если же проект требует использования продвинутых функций, таких как кэширование, гибкие механизмы запросов и другие возможности, которые выходят за рамки стандартного JPA, стоит рассмотреть использование Hibernate.
Please open Telegram to view this post
VIEW IN TELEGRAM
👾 -35% на курс по алгоритмам

На курсе вы на практике познакомитесь со сложными алгоритмами и научитесь писать более короткий и эффективный код – https://proglib.io/w/c3ea2f6f

23 390 рублей 35 990 рублей

Что еще вас ждет на курсе:

▪️ 150 практических заданий и 47 видеолекций;

▪️ Бессрочный доступ ко всем материалам курса;

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

🌚 Переходите на сайт, читайте подробности и заходите на обучение по самым выгодным условиям – https://proglib.io/w/c3ea2f6f
Please open Telegram to view this post
VIEW IN TELEGRAM
#дайджест #javadevjob

Вакансии Java разработчиков уровня Junior

▪️Младший разработчик
Удаленка. Doczilla — система управления жизненным циклом контрактов на базе ИИ
Подробнее

▪️Разработчик Java
Барнаул. ЕРЦ — Единый Расчетный Центр
Подробнее

Вакансии Java разработчиков уровня Middle

▪️Разработчик Java
Удаленка. HolyCode — разработка IT решений
Подробнее

▪️Java-разработчик
Удаленка. Смартавиа — авиакомпания
Подробнее

Вакансии Java разработчиков уровня Senior

▪️Java developer
Москва. SSP SOFT — разработка ПО
Подробнее

▪️Java Developer
Москва. Раппорто — интегратор на рынке телекоммуникаций
Подробнее

Понравились вакансии?
❤️ — да
🤔 — нет
Утро понедельника хорошо начинать с #memes
🖥 Что нового в IntelliJ IDEA 2024.2

Вышла новая версия IntelliJ IDEA 2024.2 с множеством улучшений, включая ускоренный запуск IDE и новые функции для работы с Kotlin, такие как поддержка режима K2 и улучшенный дебаггер. Теперь разработка стала еще удобнее благодаря инкрементальной синхронизации Maven-проектов и улучшенному интерфейсу. Хотите узнать больше о всех новых возможностях? Читайте статью
Please open Telegram to view this post
VIEW IN TELEGRAM
🤫 Секреты эффективной работы с ArrayList

ArrayList — это один из самых популярных классов для работы с динамическими массивами в Java. Но чтобы использовать его по максимуму, стоит учесть несколько важных моментов:

1️⃣ Уменьшайте количество расширений: Каждый раз, когда ArrayList превышает свою текущую емкость, он создает новый массив большего размера. Это может замедлить работу, особенно при больших объемах данных. Чтобы избежать этого, инициализируйте ArrayList с заранее рассчитанной емкостью, если примерно знаете объем данных.

2️⃣ Избегайте частых вставок и удалений в середине списка: Операции вставки и удаления элементов в середине ArrayList требуют сдвига всех последующих элементов. Если такие операции критичны, рассмотрите использование LinkedList.

3️⃣ Используйте метод trimToSize(): Если ваш ArrayList больше не будет изменяться, вызов метода trimToSize() освободит неиспользуемую память, оптимизируя использование ресурсов.

4️⃣ Итерации важны: Используйте цикл for-each или метод forEach() для итерации по ArrayList. Они обеспечивают более читаемый и безопасный код. Но если нужен доступ по индексу, стандартный цикл for — ваш выбор.

5️⃣ Будьте осторожны с автобоксингом: При работе с примитивными типами, такими как int, ArrayList автоматически упаковывает их в Integer. Это может привести к лишним затратам памяти. Если производительность критична, используйте специализированные классы, такие как IntArrayList из библиотеки fastutil.
Please open Telegram to view this post
VIEW IN TELEGRAM
🏗️ Структуры данных для разработчиков: 10 самых важных

Структуры данных — фундамент эффективной разработки. Кратко разберем 10 ключевых структур данных, которые необходимо освоить каждому разработчику для создания производительных и масштабируемых приложений, а подробнее читайте в статье👇

🔹 Списки отлично подходят для хранения и обработки упорядоченных данных и полезны в различных приложениях, таких как управление задачами, ленты соцсетей и корзины интернет-магазинов.
🔹 Массивы — упорядоченная коллекция элементов фиксированного размера и хорошо подходят для ситуаций, где размер коллекции известен или редко меняется.
🔹 Стеки следуют принципу «последним пришел — первым вышел». Они идеальны для реализации операций отмены/повтора в текстовых редакторах или ведения истории просмотров в веб-браузерах.
🔹 Очереди работают по принципу «первым пришел — первым вышел». Они подходят для управления заданиями печати, отправки действий пользователя в играх на сервер или обработки сообщений в чат-приложениях.
🔹 Кучи используются для планирования задач и управления памятью. Они особенно полезны в реализации очередей с приоритетами, где нужен доступ к элементу с наивысшим или наименьшим приоритетом.
🔹 Деревья организуют данные иерархически. Они полезны для представления данных с естественными иерархиями или связями и могут использоваться в различных приложениях, таких как индексация баз данных.
🔹 Хеш-таблицы позволяют эффективно искать, вставлять и удалять данные. Они используют хеш-функцию для сопоставления ключей с соответствующими местами хранения и обеспечивают доступ к сохраненным значениям за постоянное время.
🔹 Суффиксные деревья специализируются на поиске строк в документах, что делает их идеальными для текстовых редакторов и алгоритмов поиска.
🔹 Графы отслеживают отношения и находят пути, что делает их незаменимыми в социальных сетях, рекомендательных системах и алгоритмах поиска путей.
🔹 KD-деревья хороши для поиска ближайших соседей и важны для картографических приложений и геолокационных сервисов.
🕯 Паттерн Factory Method (Фабричный метод)

Factory Method — это порождающий паттерн, который предоставляет интерфейс для создания объектов в суперклассе, но позволяет подклассам изменять тип создаваемых объектов.

Использование:

🔹 Когда создание объекта зависит от контекста.
🔹 Для увеличения расширяемости кода, позволяя создавать новые типы продуктов.

Преимущества:

1️⃣ Ослабление связи между кодом и конкретными классами.
Когда вы создаете объект напрямую с помощью new, ваш код жестко привязан к конкретному классу. Если вам нужно будет заменить этот класс другим, придется изменить все места, где он используется. С фабрикой вы работаете через абстракции (интерфейсы или абстрактные классы), а конкретные реализации могут меняться без изменения основного кода.

2️⃣ Упрощение и централизованное управление созданием объектов
Фабрики могут включать сложную логику по созданию объектов, такую как:
▪️ Выбор нужного класса в зависимости от условий.
▪️ Управление жизненным циклом объекта.
▪️ Использование паттернов Singleton или Pooling внутри фабрики.

3️⃣ Поддержка расширяемости и масштабируемости
Используя фабрику, вы легко можете добавлять новые типы продуктов или изменять существующие без необходимости изменять основной код. Это упрощает расширение системы.

4️⃣ Поддержка тестирования
Фабрики облегчают тестирование кода. Вы можете использовать mock-объекты или подменять реализации фабрик для тестов, что упрощает создание тестируемых объектов и проверку кода.
Please open Telegram to view this post
VIEW IN TELEGRAM
📖 От Кнута до Седжвика: классика алгоритмической литературы

Обзор лучших книг по алгоритмам для программистов всех уровней. От иллюстрированных пособий для начинающих до фундаментальных трудов для экспертов.

🔗 Читать подборку
Когда и как использовать var, чтобы код стал понятнее?

Слышали про var? Его добавили в Java 10, чтобы облегчить нам жизнь. Но когда его лучше использовать, а когда стоит быть осторожнее?💡

Когда использовать var:

🔵 Когда всё понятно с контекста: Если тип переменной очевиден 👀, то зачем писать лишнее?

var list = new ArrayList<String>(); // Это список, и это сразу видно


🔵 Когда тип слишком громоздкий: Если объявление слишком длинное и перегружает код, var упрощает задачу:

var map = new HashMap<String, List<Integer>>(); // Чисто и просто


🔵 Короткие методы: В небольших методах с чёткой логикой, var помогает сделать код компактнее и читабельнее.

А вот где лучше избегать:

🔵 Если тип неочевиден: Когда сложно сразу понять, что это за переменная, лучше явно указать тип, чтобы не путать коллег.
var result = process(); // И что за процесс тут? 


Итог: var — отличный инструмент, но используйте его с умом. Вопрос к вам: а вы уже используете var в своих проектах? Если да, поделитесь опытом в комментариях! 👇
Please open Telegram to view this post
VIEW IN TELEGRAM
ℹ️ Как работает механизм CyclicBarrier и когда его следует использовать?

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

Как это работает:

1️⃣ Потоки выполняют свою работу.
2️⃣ Когда они достигают вызова метода await(), они останавливаются и ждут, пока все остальные потоки также достигнут барьера.
3️⃣ Как только все потоки прибыли, барьер "отпускает" их, и они продолжают выполнение.
4️⃣ CyclicBarrier можно использовать повторно (циклически), что отличает его от одноразовых барьеров, таких как CountDownLatch.

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

▪️ Когда нужно, чтобы несколько потоков координировали свои действия и начинали следующую стадию только после того, как все потоки закончат текущую работу.
▪️ Для выполнения задач, которые разбиты на несколько этапов, где каждый этап должен начаться только после завершения предыдущего всеми потоками.
Please open Telegram to view this post
VIEW IN TELEGRAM