Библиотека джависта | 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
加入频道
#дайджест #Javadevjob

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

▪️ Java Developer
Удалёнка / Офис (Москва, Новосибирск), Динамика

▪️ Backend Java-разработчик
Офис (Череповец), BIV

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

▪️ Java-разработчик
Гибрид (Москва), Онлайн-кинотеатр Иви

▪️ Java-разработчик
Офис (Томск), Банк России

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

▪️ Java Developer
Офис (Пермь) / Удалёнка, Galileosky

▪️ Java-разработчик
Гибрид (Москва), Санкт-Петербургская Международная Товарно-сырьевая Биржа

Понравились вакансии?
❤️ — да
🤔 — нет
📚 ТОП-11 книг по базам данных в 2025 году

Хотите разобраться в базах данных, но не знаете, с чего начать? Мы подготовили подборку из 11 лучших книг, которые помогут вам освоить раздичные базы данных, паттерны и антипаттерны, а также оптимизацию запросов.

🔗 Читайте в статье
🔥 Лайфхак: оптимизируем DTO с record

Вместо обычных POJO-классов для DTO используйте record (Java 14+). Меньше кода, больше удобства.

Record автоматически создает иммутабельный класс с приватными финальными полями, конструктором, геттерами, а также переопределенными методами toString(), equals() и hashCode().

Избыточно
public class User {
private final String name;
private final int age;

public User(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 "User{name='" + name + "', age=" + age + "}";
}

@Override
public boolean equals(Object obj) {
if (this == obj) return true;
if (obj == null || getClass() != obj.getClass()) return false;
User user = (User) obj;
return age == user.age && Objects.equals(name, user.name);
}

@Override
public int hashCode() {
return Objects.hash(name, age);
}
}


✔️ Красиво и лаконично
public record User(String name, int age) {}
Please open Telegram to view this post
VIEW IN TELEGRAM
💬 Как запускаете свои проекты?

🔥 — Через IDE
👾 — Через терминал
🎉 — В Docker-контейнере
⚡️ — В облаке
🤔 — Ещё не понял, как запускать
Please open Telegram to view this post
VIEW IN TELEGRAM
🕯 Паттерн Состояние (State)

State — это поведенческий паттерн, который позволяет объекту менять свое поведение в зависимости от внутреннего состояния. Вместо множества условных операторов (if-else или switch), каждое состояние представляется отдельным классом, а сам объект делегирует управление текущему состоянию.

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

🔹 Когда у объекта есть несколько состояний, и его поведение зависит от текущего состояния.
🔹 Когда код с if-else или switch начинает разрастаться и усложняет поддержку.
🔹 Когда необходимо четко разделить логику различных состояний и сделать систему более гибкой.

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

1️⃣ Избавляет от множества if-else конструкций, делая код более читаемым и поддерживаемым.
2️⃣ Облегчает добавление новых состояний без изменения существующего кода.
3️⃣ Обеспечивает инкапсуляцию логики для каждого состояния, упрощая тестирование и модификации.

Недостатки

1️⃣ Может усложнить код, если состояний слишком мало, а логика простая.
2️⃣ Увеличивает количество классов, так как каждое состояние реализуется отдельно.
3️⃣ Вводит дополнительные связи между классами состояний и контекстом.

State — мощный инструмент, когда объекту нужно динамически изменять свое поведение. Он особенно полезен в конечных автоматах, обработке пользовательских действий и моделировании процессов с четко определенными шагами.
Please open Telegram to view this post
VIEW IN TELEGRAM
Swipe right or swipe left

Что делать, если твои мэтчи в жизни не такие точные, как твой код?

Спокойно, 14 февраля в 19:00 по МСК мы разберём, как ML анализирует speed dating и предсказывает match.

📌 Мы возьмем реальные данные со speed dating.

📌 Обучим модель, которая скажет: match или swipe left.

📌 Разберём, какие признаки реально важны (спойлер: работа в IT — не прям гарантия успеха (наши маркетологи подтверждают 😥).

💡 Приходи, если хочешь прокачать свой Python, ML и, возможно, станешь идеальной парой, как самый стильные форсы.

👉 Записаться
Что такое микросервисы?

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

🔹 Ключевые принципы

Можно обновлять и масштабировать отдельные сервисы без затрагивания всей системы.
Каждый сервис выполняет свою узкую задачу.
У сервиса свои изолированные данные, код и зависимости.
Сервисы общаются через HTTP, AMQP, Kafka и другие механизмы.
Please open Telegram to view this post
VIEW IN TELEGRAM
🖥 Инструменты командной строки, которые стоит знать

В статье рассматриваются такие утилиты, как jps, jstack, jinfo, jshell, jar, java, javac, javap и jcmd.

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

🔗 Подробнее в статье
Please open Telegram to view this post
VIEW IN TELEGRAM
🔍 Scoped Values в Java 21

Разберем новую фичу Java 21 — Scoped Values, которая пришла на замену (а точнее, в дополнение) к старому доброму ThreadLocal. Если вы когда-либо мучились с ThreadLocal в многопоточных приложениях, этот пост для вас.

🔽 Проблема ThreadLocal

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

— Данные остаются в потоке, даже когда уже не нужны (утечки памяти).
— Передавать данные в дочерние потоки неудобно.
— Нужно очистить данные вручную.

Scoped Values решают эти проблемы без магии и костылей.

⚙️ Как работают Scoped Values

Scoped Values (ScopedValue<T>) создаются только один раз и не изменяются после инициализации. Они передаются вглубь стека вызовов через метод ScopedValue.where(), а не через хранение в потоке, как ThreadLocal.

▪️ Пример кода с потоками


Допустим, есть обработчик запросов, который передает идентификатор пользователя.

— С ThreadLocal код выглядел бы так:
public class ThreadLocalExample {
private static final ThreadLocal<String> USER = new ThreadLocal<>();

public static void main(String[] args) {
USER.set("Alice");
new Thread(ThreadLocalExample::process).start();
}

private static void process() {
System.out.println("User: " + USER.get()); // null: поток не видит значение
}
}


ThreadLocal привязан к потоку, а не к области выполнения. Значение не наследуется

Теперь переделаем на Scoped Values:
public class ScopedValueExample {
private static final ScopedValue<String> USER = ScopedValue.newInstance();

public static void main(String[] args) {
ScopedValue.where(USER, "Alice").run(() -> {
new Thread(ScopedValueExample::process).start();
});
}

private static void process() {
System.out.println("User: " + USER.get()); // Видит "Alice"
}
}


Scoped Values автоматически передают значение в новые потоки.

🎯 Где использовать Scoped Values


1. Контекст запроса (Request Context)
В веб-приложениях часто нужно передавать ID запроса или текущего пользователя через слои сервиса.

2. Логирование (Tracing & Logging)
Можно автоматически передавать traceId в логи.

3. Конфигурация временных параметров
Можно временно менять настройки для фрагмента кода.

ℹ️ Преимущества и недостатки

— ScopedValue быстрее и безопаснее, так как нет необходимости очищать значения вручную.
— Отлично подходит для работы с виртуальными потоками.
— Ограничение: они неизменяемые (Immutable).

💬 Уже использовали? Делитесь опытом
Please open Telegram to view this post
VIEW IN TELEGRAM
Привет! 👋

Мы готовим новые вебинары и хотим сделать их максимально полезными для вас. Это поможет нам не только создавать актуальный контент, но и развивать проект, находя новые точки контактов для вас.

Ваши ответы дадут нам понимание, какие темы и форматы действительно важны, а также помогут сделать вебинары интереснее и продуктивнее.

Заполнение займет всего пару минут, а нам это очень поможет! Спасибо, что участвуете в нашем развитии! 💙

👉 Пройти опрос
Как классическая классификация ML помогает в реальном мире

🤖 Классификация в ML — это метод обучения, в котором модель обучается на размеченных данных и предсказывает, к какому классу относится новый объект.

Фильтрация спама – чтобы в почте оставалось только важное.
Рекомендации фильмов – Netflix знает, что ты любишь!
Кредитный скоринг – банки решают, дать ли тебе займ.
Предсказание мэтчей – как на нашем вебинаре по speed dating.

14 февраля мы разберём на практике задачу классификации:

- Как выбрать оптимальные признаки

- Что делать с несбалансированными данными

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

🔥 Если уже работаешь с ML или только начинающий программист – приходи на наш вебинар, в котором мы разберем «как предсказывать мэтч на speed dating» .

Приходи!
💸 Amplicode становится платным (и остается бесплатным)

С апреля прошлого года Amplicode радовал разработчиков бесплатными инструментами для работы со Spring Boot. Теперь команда объявила, что с 15 апреля часть функционала станет доступна по подписке.

Но не волнуйтесь: базовые возможности останутся бесплатными, а новые платные функции помогут сэкономить еще больше времени и сил.

🔗 Подробнее в статье
Please open Telegram to view this post
VIEW IN TELEGRAM
#дайджест #Javadevjob

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

▪️ Java Developer
Удалёнка, Prooftech IT

▪️ Java Developer
Гибрид (Санкт-Петербург), Юниверс Дата

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

▪️ Java-разработчик
Гибрид (Москва) / Удалёнка (РФ), 1С

▪️ Java-разработчик
Удалёнка / Гибрид (Москва), Swordfish Security

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

▪️ Java-разработчик
Удалёнка / Гибрид (Москва), Notamedia

▪️ Java Developer
Удалёнка, Клевертек

Понравились вакансии?
❤️ — да
🤔 — нет
🆕 Метод HTTP QUERY

В спецификации HTTP планируют добавить новый метод — QUERY. Его задача — решить проблему перегруженных GET-запросов, когда в URL передается слишком много параметров. Длина строки запроса при этом может достигать пределов, установленных сервером или клиентом.

Порой разработчики обходят ограничение, используя POST и передавая параметры в теле запроса, что нарушает семантику HTTP. QUERY предлагает альтернативу: он работает как GET, но позволяет передавать параметры в теле запроса.
Please open Telegram to view this post
VIEW IN TELEGRAM