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

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

Цены: @heywan_media

Реклама на бирже: https://telega.in/c/+r8kkGSypBY84MmIy
Download 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
👩‍💻 Что такое PriorityBlockingQueue в Java и зачем она нужна?

PriorityBlockingQueue — это потокобезопасная очередь из java.util.concurrent, которая хранит элементы в отсортированном виде согласно их приоритету.

Она активно используется в задачах, где нужно управлять порядком обработки — например, в планировщиках, системах обработки задач и диспетчерах потоков.


• Элементы автоматически сортируются
• Работает в многопоточном режиме
• Подходит для диспетчеризации задач по приоритету

⚡️ Пример:

import java.util.concurrent.PriorityBlockingQueue;

public class Main {
public static void main(String[] args) {
PriorityBlockingQueue<Integer> queue = new PriorityBlockingQueue<>();

queue.add(5);
queue.add(1);
queue.add(3);

while (!queue.isEmpty()) {
System.out.println(queue.poll()); // ➔ 1, 3, 5
}
}
}


👀 PriorityBlockingQueue особенно полезна, когда задачи имеют приоритеты — например, обработка срочных запросов, планирование задач или распределение ресурсов.


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

Что такое Reflection в Java и как он работает?

Пример🔽
import java.lang.reflect.Field;
import java.lang.reflect.Method;

public class Main {
public static void main(String[] args) throws Exception {
Class<?> clazz = Person.class;

System.out.println("Поля:");
for (Field f : clazz.getDeclaredFields())
System.out.println(" - " + f.getName());

System.out.println("\nМетоды:");
for (Method m : clazz.getDeclaredMethods())
System.out.println(" - " + m.getName());

Person p = new Person("Alice");
Method sayHello = clazz.getDeclaredMethod("sayHello");
sayHello.invoke(p); // вызов приватного метода через Reflection
}
}

class Person {
private String name;
public Person(String name) { this.name = name; }
private void sayHello() { System.out.println("Привет, " + name); }
}


Ответ🔽
Reflection (рефлексия) позволяет анализировать и изменять поведение классов во время выполнения. С её помощью можно:

— получать информацию о классах, полях и методах
— вызывать методы и изменять поля динамически
— создавать экземпляры классов без new

📌 Минусы:
— снижает производительность,
— нарушает инкапсуляцию,
— может вызывать ошибки безопасности.

Reflection активно используется в фреймворках (Spring, Hibernate, JUnit) для внедрения зависимостей, сериализации и динамического вызова кода


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

class Parent {
static void print() {
System.out.print("Parent ");
}

void show() {
System.out.print("ParentShow ");
}
}

class Child extends Parent {
static void print() {
System.out.print("Child ");
}

@Override
void show() {
System.out.print("ChildShow ");
}
}

public class Main {
public static void main(String[] args) {
Parent obj = new Child();
obj.print();
obj.show();

Child child = new Child();
child.print();
}
}


➡️ Easy Java | #Викторина
Please open Telegram to view this post
VIEW IN TELEGRAM
2
👩‍💻 Kotlin vs Java: что выбрать для бэкенда?

Вечное противостояние и споры: что выбрать? Kotlin или Java? Какой язык актуальнее в 2026 году?

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

А если вам лень читать, победитель - Java, но с небольшим отрывом, т.к Kotlin постепенно догоняет по всем направлениям.

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

➡️ 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
👩‍💻 Что такое Stream.peek() и зачем он нужен?

peek() — это промежуточный метод стримов, который позволяет выполнить произвольное действие над каждым элементом без изменения самих элементов. Классический use case: отладка пайплайнов, логирование, заполнение внешних коллекций.

⚡️ Пример:

import java.util.*;
import java.util.stream.*;

public class PeekExample {
public static void main(String[] args) {
List<String> log = new ArrayList<>();

List<String> result = Stream.of("java", "python", "rust")
.peek(s -> System.out.println("До фильтра: " + s))
.filter(s -> s.length() > 3)
.peek(s -> System.out.println("После фильтра: " + s))
.map(String::toUpperCase)
.peek(log::add) // побочный эффект
.collect(Collectors.toList());

System.out.println("Результат: " + result);
System.out.println("Лог: " + log);
}
}


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


➡️ Easy Java | #Теория
Please open Telegram to view this post
VIEW IN TELEGRAM
👍31
👩‍💻 Викторина: что выведет код?

public class Main {
static int x = 0;

public static void main(String[] args) throws InterruptedException {
Thread t1 = new Thread(() -> {
for (int i = 0; i < 1000; i++) x++;
});
Thread t2 = new Thread(() -> {
for (int i = 0; i < 1000; i++) x++;
});
t1.start();
t2.start();
Thread.sleep(100);
System.out.print(x);
}
}


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

Phaser — это продвинутый синхронизатор из java.util.concurrent, который позволяет потокам координироваться по фазам выполнения.

В отличие от CountDownLatch и CyclicBarrier, он гибче: количество участников можно динамически добавлять и убирать.


• Поддерживает несколько фаз
• Гибко управляет количеством потоков
• Удобен для пошаговых алгоритмов

⚡️ Пример:

import java.util.concurrent.Phaser;

public class Main {
public static void main(String[] args) {
Phaser phaser = new Phaser(3);

Runnable task = () -> {
System.out.println(Thread.currentThread().getName() + " — фаза 1");
phaser.arriveAndAwaitAdvance();
System.out.println(Thread.currentThread().getName() + " — фаза 2");
};

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


👀 Phaser особенно полезен для задач с несколькими этапами синхронизации — например, симуляций, параллельных вычислений или координации батчевых операций


➡️ 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
🤣11👍1
👩‍💻 Качество кода в эпоху AI: как не утонуть в багах и уязвимостях

Автор разбирает, почему внедрение AI может снижать продуктивность, раздувать время ревью и плодить уязвимости. И главное — как это лечить не магическими промптами, а инженерным пайплайном: SDD, TDD, узкие AI-ревьюеры, property-based testing и связка LLM с формальными анализаторами.

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

➡️ Easy Java | #Статья
Please open Telegram to view this post
VIEW IN TELEGRAM
3
👩‍💻 Викторина: что выведет код?

class Parent {
static String show() {
return "Parent";
}

String print() {
return show();
}
}

class Child extends Parent {
static String show() {
return "Child";
}
}

public class Main {
public static void main(String[] args) {
Parent p = new Child();
System.out.println(p.print());
}
}


➡️ Easy Java | #Викторина
Please open Telegram to view this post
VIEW IN TELEGRAM
😁6🤔2🔥1