Java | Фишки и трюки
7.21K subscribers
182 photos
29 videos
6 files
40 links
Java: примеры кода, интересные фишки и полезные трюки

Купить рекламу: https://telega.in/c/java_tips_and_tricks

✍️По всем вопросам: @Pascal4eg
Download Telegram
🚀 Секреты работы с VarHandle и как они могут заменить рефлексию

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

🔍 Зачем использовать VarHandle вместо рефлексии?
1️⃣ ПроизводительностьVarHandle предоставляет прямой доступ к полям и переменным, минуя накладные расходы, которые присущи рефлексии.
2️⃣ Поддержка атомарных операцийVarHandle поддерживает атомарные операции, такие как чтение и запись, что полезно в многозадачности.
3️⃣ Типобезопасность — в отличие от рефлексии, VarHandle является типобезопасным, что уменьшает количество ошибок при компиляции.

📌 Как использовать VarHandle?
1️⃣ Используйте метод VarHandles.lookup() для получения экземпляра VarHandle.
2️⃣ Используйте его для чтения и записи значений в поля объектов.
3️⃣ Поддерживает операции, такие как get(), set(), а также атомарные операции.

📌 Пример использования VarHandle:

import java.lang.invoke.*;

public class VarHandleExample {
private String field = "Initial Value";

public static void main(String[] args) throws Throwable {
VarHandleExample example = new VarHandleExample();
VarHandle varHandle = MethodHandles.lookup().findVarHandle(VarHandleExample.class, "field", String.class);

// Чтение значения через VarHandle
System.out.println("Current value: " + varHandle.get(example));

// Изменение значения через VarHandle
varHandle.set(example, "Updated Value");
System.out.println("Updated value: " + varHandle.get(example));

// Атомарное обновление значения
boolean success = varHandle.compareAndSet(example, "Updated Value", "New Value");
System.out.println("Atomic update successful: " + success);
System.out.println("Final value: " + varHandle.get(example));
}
}


Когда использовать VarHandle вместо рефлексии?
- Когда необходимо работать с полями объектов или массивами без накладных расходов рефлексии.
- Для оптимизации производительности в многозадачных приложениях.
- Когда нужно обеспечить типобезопасность и атомарность операций при работе с полями.

#Java #VarHandle #Reflection #Concurrency #Performance
👍132
Что такое AtomicInteger и зачем он нужен?

AtomicInteger — это класс из java.util.concurrent.atomic, который предоставляет атомарные операции над int без использования synchronized.

➡️ Зачем использовать?

1️⃣ Позволяет безопасно изменять значение в многопоточной среде.
2️⃣ Работает быстрее, чем synchronized, так как использует низкоуровневые атомарные операции.

✔️ Пример:

import java.util.concurrent.atomic.AtomicInteger;

public class AtomicExample {
private static AtomicInteger count = new AtomicInteger(0);

public static void main(String[] args) {
count.incrementAndGet(); // Увеличиваем значение на 1
System.out.println(count.get()); // 1
}
}


💡 Совет: Используйте AtomicInteger, если вам нужны безопасные инкременты/декременты без блокировки.

#java #atomicinteger #concurrency
Please open Telegram to view this post
VIEW IN TELEGRAM
👍82
🔄 StructuredTaskScope — это класс, появившийся в Java 21 в рамках проекта Loom, который помогает управлять группами фоновых задач в многопоточной среде. Он предоставляет удобный механизм для управления задачами в рамках структурированного параллелизма (Structured Concurrency).

📌 Для чего нужен StructuredTaskScope?

🟢Управление жизненным циклом нескольких задач в пределах одного контекста.
🟢Упрощение обработки исключений и отмены всех задач при сбое одной из них.
🟢Автоматическое ожидание завершения всех задач.
🟢Оптимизация работы с виртуальными потоками (Virtual Threads), повышая эффективность работы.

✔️ Преимущества StructuredTaskScope

🟢Простота кода – избавляет от ручного управления Future, CompletableFuture и ExecutorService.
🟢Безопасность – если одна задача падает, можно отменить другие.
🟢Эффективность – интеграция с виртуальными потоками позволяет выполнять множество задач с минимальными накладными расходами.

➡️ Пример:


import java.util.concurrent.*;

public class StructuredTaskScopeExample {

public static void main(String[] args) throws InterruptedException, ExecutionException {
try (var scope = new StructuredTaskScope.ShutdownOnFailure()) {
// Запускаем две параллельные задачи
var task1 = scope.fork(() -> fetchDataFromAPI("API 1"));
var task2 = scope.fork(() -> fetchDataFromAPI("API 2"));

// Дожидаемся завершения (или отмены в случае ошибки)
scope.join();
scope.throwIfFailed(); // Выбросит исключение, если одна из задач завершилась с ошибкой

// Получаем результаты
String result1 = task1.get();
String result2 = task2.get();

System.out.println("Result 1: " + result1);
System.out.println("Result 2: " + result2);
}
}

private static String fetchDataFromAPI(String apiName) throws InterruptedException {
Thread.sleep(1000); // Имитация задержки запроса
if (Math.random() > 0.8) throw new RuntimeException(apiName + " failed!"); // Имитация ошибки
return apiName + " response";
}
}


#java #concurrency #structuredconcurrency
Please open Telegram to view this post
VIEW IN TELEGRAM
👍14