Easy Java
5.22K subscribers
311 photos
51 videos
462 links
Лучшие обучающие материалы и другие полезности для Java-разработчиков.

Сотрудничество: @heywan_n1

Цены: @heywan_media

Реклама на бирже: https://telega.in/c/+r8kkGSypBY84MmIy
Download Telegram
👩‍💻 Шаблоны проектирования, реализованные в Java

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

Переход к репозиторию

➡️ Easy Java | #Ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5
Редко, когда сразу пишут всю правду о вакансии😁

➡️ Easy Java | #Мем
Please open Telegram to view this post
VIEW IN TELEGRAM
😁6🤣1
👩‍💻 Что такое Collections.unmodifiableList() и зачем он нужен?

Collections.unmodifiableList() — это статический метод, который создает неизменяемую (read-only) обертку над существующим списком. Любая попытка изменить такой список приводит к выбросу UnsupportedOperationException.

⚡️ Пример:
import java.util.*;

public class UnmodifiableListExample {
public static void main(String[] args) {
// Создаем изменяемый список
List<String> mutableList = new ArrayList<>();
mutableList.add("Java");
mutableList.add("Python");
mutableList.add("C++");

// Создаем неизменяемую обертку
List<String> immutableList = Collections.unmodifiableList(mutableList);

System.out.println("Исходный список: " + mutableList);
System.out.println("Неизменяемая обертка: " + immutableList);

// Попытка изменить неизменяемый список
try {
immutableList.add("JavaScript"); // Бросит исключение
} catch (UnsupportedOperationException e) {
System.out.println("Ошибка: нельзя добавить элемент в неизменяемый список");
}

try {
immutableList.remove(0); // Бросит исключение
} catch (UnsupportedOperationException e) {
System.out.println("Ошибка: нельзя удалить элемент из неизменяемого списка");
}

// Важно: изменения в оригинальном списке отражаются в обертке!
mutableList.add("JavaScript");
System.out.println("После изменения оригинала:");
System.out.println("Оригинал: " + mutableList);
System.out.println("Обертка: " + immutableList); // JavaScript появился и здесь

// Правильный способ - полная копия
List<String> safeImmutable = Collections.unmodifiableList(
new ArrayList<>(mutableList) // Создаем копию
);

// Использование в API
DataService service = new DataService();
List<String> data = service.getReadOnlyData();

try {
data.add("Новый элемент"); // Ошибка - список только для чтения
} catch (UnsupportedOperationException e) {
System.out.println("API вернуло защищенные данные");
}
}

static class DataService {
private List<String> internalData = Arrays.asList("A", "B", "C");

public List<String> getReadOnlyData() {
// Возвращаем неизменяемую обертку для защиты данных
return Collections.unmodifiableList(internalData);
}
}
}


Особенно полезен при возврате данных из API, передаче коллекций в методы, создании константных коллекций и защите внутреннего состояния объекта от внешних изменений.


➡️ Easy Java | #Теория
Please open Telegram to view this post
VIEW IN TELEGRAM
Вопрос с собеса

Чем ReentrantLock отличается от synchronized в Java?

Пример🔽
import java.util.concurrent.locks.ReentrantLock;

public class Main {
private static final ReentrantLock lock = new ReentrantLock();
private static int counter = 0;

public static void main(String[] args) {
Runnable task = () -> {
lock.lock();
try {
counter++;
} finally {
lock.unlock();
}
};

new Thread(task).start();
new Thread(task).start();
}
}


Ответ🔽
ReentrantLock — это класс из java.util.concurrent.locks, который предоставляет больше возможностей, чем synchronized:

— Можно пытаться захватить блокировку с таймаутом (tryLock)
— Можно использовать блокировку с несколькими условиями (Condition)
— Можно вручную управлять моментом захвата и освобождения

📌 В отличие от synchronized, ReentrantLock требует явного вызова lock() и unlock(), что даёт гибкость, но требует дисциплины.


➡️ Easy Java | #Собес
Please open Telegram to view this post
VIEW IN TELEGRAM
😁4🤯1
👩‍💻 Марафон на GitHub: Java за 30 дней

Пошаговое руководство по изучению языка программирования JavaScript за 30 дней, подойдет преимущественно для новичков. Несмотря на свое название, курс может занять более 100 дней, однако, все зависит только от вас.

В курсе темы поделены по дням начиная с самой базы и заканчивая визуализацией и анимацией.

Ссылка на курс

➡️ Easy Java | #Ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
🤣6🤡5👍1💩1
👩‍💻 Викторина: что выведет код?

public class Main {
private static ThreadLocal<String> threadLocal = new ThreadLocal<>();
private static InheritableThreadLocal<String> inheritable = new InheritableThreadLocal<>();

public static void main(String[] args) {
threadLocal.set("main");
inheritable.set("main");

Thread child = new Thread(() -> {
System.out.print(threadLocal.get() + " ");
System.out.print(inheritable.get() + " ");

inheritable.set("child");

Thread grandChild = new Thread(() -> {
System.out.print(inheritable.get());
});
grandChild.start();
try { grandChild.join(); } catch (Exception e) {}
});

child.start();
}
}


➡️ Easy Java | #Викторина
Please open Telegram to view this post
VIEW IN TELEGRAM
😁1
Всем бы такие софт-скиллы...

➡️ Easy Java | #Мем
Please open Telegram to view this post
VIEW IN TELEGRAM
🤡6🤔31👍1🥰1
👩‍💻 Что такое Optional.ifPresent() и зачем он нужен?

Optional.ifPresent() — это метод класса Optional<T>, который выполняет заданное действие, если значение присутствует. Если значение отсутствует, ничего не происходит.

⚡️ Пример:
import java.util.*;

public class IfPresentExample {
public static void main(String[] args) {
// Поиск пользователя
Optional<String> email = findUserEmail(123);

// Старый способ (много кода)
if (email.isPresent()) {
sendEmail(email.get(), "Привет!");
}

// Новый способ (кратко и элегантно)
email.ifPresent(e -> sendEmail(e, "Привет!"));

// С method reference
email.ifPresent(System.out::println);

// Работа со списком опциональных значений
List<Optional<String>> names = Arrays.asList(
Optional.of("Анна"),
Optional.empty(),
Optional.of("Иван")
);

// Обрабатываем только существующие значения
names.forEach(opt ->
opt.ifPresent(name ->
System.out.println("Привет, " + name)
)
);
// Вывод: Привет, Анна
// Привет, Иван
}

static Optional<String> findUserEmail(int id) {
return id == 123 ?
Optional.of("user@mail.com") :
Optional.empty();
}

static void sendEmail(String email, String msg) {
System.out.println("Отправлено на " + email + ": " + msg);
}
}


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


➡️ Easy Java | #Теория
Please open Telegram to view this post
VIEW IN TELEGRAM
👩‍💻 Универсальный инструмент для работы с базами данных и SQL-клиент

Бесплатный многоплатформенный инструмент для работы с базами данных, предназначенный для разработчиков, SQL-программистов, администраторов и аналитиков баз данных.

Обладает множеством функций , включая редактор схем, редактор SQL, редактор данных, интеграцию с ИИ, ER-диаграммы, экспорт/импорт/миграцию данных, планы выполнения SQL-запросов, инструменты администрирования баз данных, панели мониторинга баз данных, средство просмотра пространственных данных, прокси-сервер и SSH-туннелирование, редактор пользовательских драйверов баз данных и т.д.

Ссылка на GitHub

➡️ Easy Java | #Ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
1🔥1
👩‍💻 Викторина: что выведет код?

public class Main {
static class A {
static final B b = new B();
static final int value = 42;
}

static class B {
static final int value = A.value;
}

public static void main(String[] args) {
System.out.println(A.b.value);
}

➡️ Easy Java | #Викторина
Please open Telegram to view this post
VIEW IN TELEGRAM
1
🤔2
Признайтесь, каждый из вас ждет такую вакансию

➡️ Easy Java | #Мем
Please open Telegram to view this post
VIEW IN TELEGRAM
😁14
👩‍💻 Что такое LocalDate.now() и зачем он нужен?

LocalDate.now() — это статический метод класса java.time.LocalDate, который возвращает текущую дату в системном часовом поясе.



⚡️ Пример:

import java.time.*;
import java.time.format.*;

public class LocalDateExample {
public static void main(String[] args) {
// Получение текущей даты
LocalDate today = LocalDate.now();
System.out.println("Сегодня: " + today);

// Разные форматы
System.out.println("Год: " + today.getYear());
System.out.println("Месяц: " + today.getMonth());
System.out.println("День недели: " + today.getDayOfWeek());

// Форматирование
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd.MM.yyyy");
System.out.println("Форматированная: " + today.format(formatter));

// Арифметика с датами
LocalDate nextWeek = today.plusDays(7);
LocalDate nextMonth = today.plusMonths(1);
System.out.println("Через неделю: " + nextWeek);
System.out.println("Через месяц: " + nextMonth);

// Сравнение дат
if (today.isAfter(LocalDate.of(2024, 1, 1))) {
System.out.println("Мы уже в 2024 году или позже");
}
}
}

Особенно полезен при логировании даты событий, расчете сроков, фильтрации записей и генерации отчетов.


➡️ Easy Java | #Теория
Please open Telegram to view this post
VIEW IN TELEGRAM
😁2
👩‍💻 Event Loop в Java для начинающих

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

Но что делать интерпретатору, если он встречает код, который не может выполнить сразу? Именно про это вы узнаете в данной статье

Читаем по ссылке

➡️ Easy Java | #Ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
🤔4🤡3
👩‍💻 Викторина: что выведет код?

public class Main {
public static void main(String[] args) {
try {
throw new RuntimeException("Oops");
} catch (Exception e) {
System.out.print("A");
} finally {
System.out.print("B");
}
System.out.print("C");
}
}


➡️ Easy Java | #Викторина
Please open Telegram to view this post
VIEW IN TELEGRAM
1
👩‍💻 Что такое CompletableFuture.supplyAsync() и зачем он нужен?

Это статический метод для асинхронного выполнения задачи с возвратом результата. Он запускает код в отдельном потоке из общего пула (ForkJoinPool.commonPool()), не блокируя главный поток.

⚡️ Пример:

import java.util.concurrent.*;

public class AsyncExample {
public static void main(String[] args) throws Exception {
System.out.println("Начало: " + Thread.currentThread().getName());

// Асинхронный вызов API / тяжёлый расчёт
CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> {
try {
Thread.sleep(2000); // симуляция долгой операции
} catch (InterruptedException e) { }
return "Результат: " + Thread.currentThread().getName();
});

System.out.println("Главный поток не заблокирован");

// Получение результата (блокируется, только если надо)
String result = future.join();
System.out.println(result);
}
}


Особенно полезен при вызове внешних API, параллельной обработке списков, построении неблокирующих пайплайнов


➡️ Easy Java | #Теория
Please open Telegram to view this post
VIEW IN TELEGRAM
1👍1
Те самые странные сны…

➡️ Easy Java | #Мем
Please open Telegram to view this post
VIEW IN TELEGRAM
😁6
👩‍💻 Guardrails для LLM на Java: как приручить промпт‑инъекции и токсичные ответы

Автор объясняет, почему стандартные системные промпты недостаточны для защиты от таких угроз, как:

- Prompt injection / jailbreak (взлом модели через специальные инструкции)
- Утечка PII (личных данных, email, номеров карт)
- Токсичные ответы LLM
- Запрещенные темы и атаки переполнения контекста

В качестве решения предлагается JGuardrails — Java-библиотека (Java 17+), работающая как фильтр до и после вызова LLM на уровне кода, без привязки к фреймворку.

 К прочтению по ссылке

➡️ Easy Java | #Статья
Please open Telegram to view this post
VIEW IN TELEGRAM