Java Ready | Программирование
8.9K subscribers
1.22K photos
60 videos
1 file
597 links
Авторский канал по разработке на Java.
Ресурсы, гайды, задачи, шпаргалки.
Информация ежедневно пополняется!

Автор: @energy_it

Реклама на бирже: https://telega.in/c/java_ready
Download Telegram
This media is not supported in your browser
VIEW IN TELEGRAM
✍️ AlgoTree — понятные объяснения алгоритмов, деревьев и графов!

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

📌 Оставляю ссылочку: algotree.org

👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
👍126🔥5🤝3
Защита от повторного запуска!

Иногда приложение нельзя запускать дважды, второй экземпляр создаёт конфликты и ошибки. Решение создать lock-файл, первый запуск ставит блокировку, второй сразу выходит.

Создаём lock-файл:
Path lockPath = Path.of("app.lock");


Открываем и пытаемся заблокировать:
FileChannel ch = FileChannel.open(lockPath,
StandardOpenOption.CREATE, StandardOpenOption.WRITE);

FileLock lock = ch.tryLock();


Если блокировка не получена — второй запуск запрещён:
if (lock == null) {
System.out.println("Экземпляр уже запущен");
System.exit(1);
}


Если всё ок, то приложение работает:
System.out.println("Запуск разрешён ");


👉 Java Ready | #совет
Please open Telegram to view this post
VIEW IN TELEGRAM
7👍6🔥3
This media is not supported in your browser
VIEW IN TELEGRAM
😎 Java Design Patterns — удобный и компактный сайт с реализациями всех популярных шаблонов проектирования на Java!

Каждый шаблон снабжён кратким описанием, структурной диаграммой и кодом. Подойдёт как для повторения, так и для практики при разработке крупных проектов.

📌 Оставляю ссылочку: refactoring.guru

👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
👍12🔥86
Генератор резервной копии папки!

Резервные копии спасают от случайных удалений и ошибок. В Java можно скопировать целую папку со всеми файлами.

Указываем исходную папку и каталог для резервной копии:
var source = java.nio.file.Path.of("data");
var backup = java.nio.file.Path.of("backup");


Создаём папку для бэкапа, если её ещё нет:
if (!java.nio.file.Files.exists(backup))
java.nio.file.Files.createDirectory(backup);


Проходим по файлам в исходной папке:
try (var paths = java.nio.file.Files.list(source)) {
paths.forEach(p -> {


Копируем каждый файл в папку backup:
        try {
var target = backup.resolve(p.getFileName());
java.nio.file.Files.copy(
p, target,
java.nio.file.StandardCopyOption.REPLACE_EXISTING
);
} catch (Exception e) {
System.out.println("Ошибка: " + p.getFileName());
}
});
}


Сообщаем о результате:
System.out.println("Резервная копия создана в папке backup");


В итоге получаем копию всех файлов из data в backup.

👉 Java Ready | #практика
Please open Telegram to view this post
VIEW IN TELEGRAM
👍96🔥4😁1
👩‍💻 Создадим свой мини логгер!

Когда не хочется тянуть библиотеки ради простого логирования можно сделать всё вручную. Добавим уровни (INFO, WARN, ERROR), цвет в консоли и текущее время.

В этом посте:
Напишем метод log() с цветным выводом.

Добавим уровни сообщений.

Получим формат: [INFO] 12:44:05 - Сообщение.


Подходит для отладки, мини-приложений и утилит.

👉 Java Ready | #гайд
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥147👍6
📂 Напоминалка по сетевой диагностике!

Например, ping используется для проверки доступности узла и времени отклика, ss и netstat позволяют определить открытые порты и активные соединения.

На изображении — самые часто используемые сетевые команды для Linux/macOS и Windows, которые применяются при анализе сетевых сбоев, проблем с подключением и производительностью.

Сохрани, чтобы не забыть!

👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
12🔥7👍6🤝3
Очередь задач!

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

Создаём очередь задач:
BlockingQueue<Runnable> queue = new LinkedBlockingQueue<>();


Добавляем задачи в очередь:
queue.add(() -> System.out.println("Задача 1 выполнена"));
queue.add(() -> System.out.println("Задача 2 выполнена"));


Запускаем обработчик очереди:
while (true) {
Runnable task = queue.take();
task.run();
}


🔥 Такой подход используют в: фоновых сервисах, обработке событий, загрузчиках и воркерах

👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
10👍7🔥5
This media is not supported in your browser
VIEW IN TELEGRAM
💡 Awesome Java — крутая подборка ресурсов для любого уровня!

Целый каталог материалов: библиотеки, фреймворки, статьи, туториалы, книги, проекты, инструменты и ссылки на полезные сообщества. Репозиторий охватывает всё, от основ языка и JVM до продвинутых тем. Полезно тем, кто хочет структурировать обучение, подобрать ресурсы под конкретную задачу или пополнить свой набор инструментов.

Оставляю ссылочку: GitHub 📱


👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
12🔥9🤝5👍4
Генерация deterministic ID!

Иногда UUID не подходит и нужен ID, который стабилен и повторяем. Удобно для кэшей, ключей и записей.

Задаём входные данные, из которых будем делать ID:
String input = "user:alice@example.com";


Хешируем строку алгоритмом SHA-256:
var md = java.security.MessageDigest.getInstance("SHA-256");
byte[] hash = md.digest(input.getBytes(java.nio.charset.StandardCharsets.UTF_8));


Переводим байты в компактный HEX-вид:
var sb = new StringBuilder();
for (byte b : hash) sb.append(String.format("%02x", b));


Берём первые 12 символов:
String id = sb.substring(0, 12);
System.out.println("ID: " + id);


Можно менять длину ID и использовать как ключ в базе, кэше или логах.

👉 Java Ready | #практика
Please open Telegram to view this post
VIEW IN TELEGRAM
8👍6🔥4
📂 Напоминалка по состояниям потоков в Java!

Поток в Java может находиться в одном из 6 состояний: NEW, RUNNABLE, BLOCKED, WAITING, TIMED_WAITING, TERMINATED.
На картинке чёткая схема переходов между ними с указанием методов, которые это вызывают.

Сохрани, чтобы не запутаться!

👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
👍165🔥5
👩‍💻 Асинхронность — способ делать программы эффективными!

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

Java позволяет управлять асинхронностью постепенно: от простых потоков до пулов задач с контролируемым жизненным циклом.


👉 Java Ready | #шпора
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥18👍6🤝64
📂 Напоминалка по атакам на пароли!

Например, brute force и dictionary attack используются для перебора паролей, credential stuffing и password spraying — для атак с украденными учетными данными.

На изображении — основные типы атак на пароли и способы кражи учетных данных.

Сохрани, чтобы не забыть!

👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
10🤝7👍6🔥2
Добавляем водяной знак в PDF

Расскажу как можно добавить на ваш PDF-файл водяной знак для защиты его от копирования.

Открываем PDF:
PDDocument doc = PDDocument.load(new File("input.pdf"));


Берём страницу и начинаем рисовать поверх:
PDPage page = doc.getPage(0);
PDPageContentStream cs =
new PDPageContentStream(doc, page, AppendMode.APPEND, true);


Добавляем текст водяного знака:
cs.beginText();
cs.setFont(PDType1Font.HELVETICA_BOLD, 48);
cs.setNonStrokingColor(200, 200, 200);
cs.setTextMatrix(Matrix.getRotateInstance(
Math.toRadians(45), 150, 300));
cs.showText("CONFIDENTIAL");
cs.endText();


Сохраняем результат:
cs.close();
doc.save("output.pdf");
doc.close();


Водяной знак помогает: защитить документы, помечать файлы и отслеживать утечки

👉 Java Ready | #совет
Please open Telegram to view this post
VIEW IN TELEGRAM
7👍6🔥5