Please open Telegram to view this post
VIEW IN TELEGRAM
😁6🤣1
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, передаче коллекций в методы, создании константных коллекций и защите внутреннего состояния объекта от внешних изменений.
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(), что даёт гибкость, но требует дисциплины.
Please open Telegram to view this post
VIEW IN TELEGRAM
😁4🤯1
Пошаговое руководство по изучению языка программирования JavaScript за 30 дней, подойдет преимущественно для новичков. Несмотря на свое название, курс может занять более 100 дней, однако, все зависит только от вас.
В курсе темы поделены по дням начиная с самой базы и заканчивая визуализацией и анимацией.
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();
}
}Please open Telegram to view this post
VIEW IN TELEGRAM
Что выведет код?
Anonymous Quiz
25%
A) null main child
12%
B) null main main
47%
C) main main child
15%
D) main main null
😁1
Please open Telegram to view this post
VIEW IN TELEGRAM
🤡6🤔3❤1👍1🥰1
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);
}
}
Особенно полезен для отправки уведомлений при наличии данных, логировании опциональных значений, обновлении объектов, выполнении побочных эффектов, обработке результатов поиска.
Please open Telegram to view this post
VIEW IN TELEGRAM
Бесплатный многоплатформенный инструмент для работы с базами данных, предназначенный для разработчиков, SQL-программистов, администраторов и аналитиков баз данных.
Обладает множеством функций , включая редактор схем, редактор SQL, редактор данных, интеграцию с ИИ, ER-диаграммы, экспорт/импорт/миграцию данных, планы выполнения SQL-запросов, инструменты администрирования баз данных, панели мониторинга баз данных, средство просмотра пространственных данных, прокси-сервер и SSH-туннелирование, редактор пользовательских драйверов баз данных и т.д.
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);
}
Please open Telegram to view this post
VIEW IN TELEGRAM
❤1
Что выведет код?
Anonymous Quiz
46%
А) 42
8%
B) 0
33%
C) Ошибка компиляции
14%
D) StackOverflowError
🤔2
Please open Telegram to view this post
VIEW IN TELEGRAM
😁14
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 году или позже");
}
}
}
Особенно полезен при логировании даты событий, расчете сроков, фильтрации записей и генерации отчетов.
Please open Telegram to view this post
VIEW IN TELEGRAM
😁2
JavaScript выполняет код в одном основном потоке. Это означает, что инструкции выполняются последовательно — одна за другой. Получил команду — выполнил.
Но что делать интерпретатору, если он встречает код, который не может выполнить сразу? Именно про это вы узнаете в данной статье
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");
}
}Please open Telegram to view this post
VIEW IN TELEGRAM
❤1
Это статический метод для асинхронного выполнения задачи с возвратом результата. Он запускает код в отдельном потоке из общего пула (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, параллельной обработке списков, построении неблокирующих пайплайнов
Please open Telegram to view this post
VIEW IN TELEGRAM
❤1👍1
Please open Telegram to view this post
VIEW IN TELEGRAM
😁6
Автор объясняет, почему стандартные системные промпты недостаточны для защиты от таких угроз, как:
- Prompt injection / jailbreak (взлом модели через специальные инструкции)
- Утечка PII (личных данных, email, номеров карт)
- Токсичные ответы LLM
- Запрещенные темы и атаки переполнения контекста
В качестве решения предлагается JGuardrails — Java-библиотека (Java 17+), работающая как фильтр до и после вызова LLM на уровне кода, без привязки к фреймворку.
Please open Telegram to view this post
VIEW IN TELEGRAM
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 особенно полезна, когда задачи имеют приоритеты — например, обработка срочных запросов, планирование задач или распределение ресурсов.
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) для внедрения зависимостей, сериализации и динамического вызова кода
Please open Telegram to view this post
VIEW IN TELEGRAM