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

Автор: @energy_it

Реклама на бирже: https://telega.in/c/java_ready
Download Telegram
Создаём гифку из фото

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

Собираем список кадров:
File[] frames = new File("images").listFiles((dir, name) ->
name.endsWith(".png") || name.endsWith(".jpg"));


Читаем изображения в память:
BufferedImage img = ImageIO.read(frames[i]);


Добавляем кадры в GIF по очереди:
gifWriter.writeToSequence(
new IIOImage(img, null, metadata),
params
);


Задаём задержку между кадрами:
metadataNode.setAttribute("delayTime", "50");


Сохраняем готовую анимацию:
output.close();
gifWriter.endWriteSequence();


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

👉 Java Ready | #совет
Please open Telegram to view this post
VIEW IN TELEGRAM
7🔥4👍3
This media is not supported in your browser
VIEW IN TELEGRAM
🐱 Java — практическая база по Java и ООП!

Это структурированная подборка материалов и примеров по основам Java. Внутри разобраны ключевые темы: классы и объекты, наследование, полиморфизм, коллекции, обработка исключений и базовые алгоритмы. Материал подаётся через код и примеры, что позволяет сразу видеть, как применяются концепции на практике.

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


👉 Java Ready | #репозиторий
Please open Telegram to view this post
VIEW IN TELEGRAM
👍96🔥6
Создаём консольный редактор текста

Пользователь вводит текст, добавляет новые строки, удаляет лишнее и в любой момент может посмотреть текущее содержимое.
Такой проект хорошо показывает, как строится логика приложения с командами, хранением данных и циклом работы.

Храним все строки текста в списке:
List<String> lines = new ArrayList<>();


Считываем команду от пользователя:
System.out.print("Команда: ");
String cmd = sc.nextLine();


Добавляем новую строку в редактор:
System.out.print("Введите текст: ");
String text = sc.nextLine();
lines.add(text);


Показываем всё содержимое с номерами строк:
for (int i = 0; i < lines.size(); i++) {
System.out.println((i + 1) + ": " + lines.get(i));
}


Удаляем строку по номеру:
System.out.print("Номер строки: ");
int index = Integer.parseInt(sc.nextLine()) - 1;
lines.remove(index);


Сохраняем текст в файл:
Files.write(Path.of("note.txt"), lines);


Загружаем текст из файла обратно:
lines = Files.readAllLines(Path.of("note.txt"));


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

👉 Java Ready | #совет
Please open Telegram to view this post
VIEW IN TELEGRAM
4👍3🔥3
Парсинг HTML через Jsoup!

Собираем данные со страниц: тянем заголовки и ссылки, удобно для ботов, парсеров и быстрых утилит.

Устанавливаем библиотеку:
implementation "org.jsoup:jsoup:1.17.2"


Извлекаем заголовки h1..h3:
var url = "https://java.com";
var doc = org.jsoup.Jsoup.connect(url).get();

doc.select("h1, h2, h3").forEach(h -> {
System.out.println(h.tagName() + ": " + h.text());
});
// h1: Example Domain
// h2:


Собираем ссылки с текстами:
doc.select("a[href]").forEach(a -> {
var href = a.attr("abs:href"); // абсолютная ссылка
var text = a.text();
System.out.println(text + " -> " + href);
});


Массовый парсинг нескольких страниц:
var urls = java.util.List.of(
"https://example.com",
"https://example.org"
);
for (var u : urls) {
var d = org.jsoup.Jsoup.connect(u).get();
System.out.println("== " + u + " ==");
d.select("title").forEach(t -> System.out.println(t.text()));
}


🔥 Быстро вытягиваем метаданные, заголовки и ссылки: идеально для агрегаторов, мониторинга и автосборки контента.

👉 Java Ready | #практика
Please open Telegram to view this post
VIEW IN TELEGRAM
5👍3🔥2
📂 Напоминалка по тому, как работает JVM!

Например, Java-код сначала компилируется в байткод (.class), а затем JVM загружает его, проверяет, и выполняет — либо через интерпретатор, либо через JIT-компиляцию в машинный код.

На схеме — полный пайплайн: от сборки (javac) до выполнения, включая загрузчики классов, этапы линковки и области памяти (heap, stack, method area), а также работу execution engine и JNI.

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

👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥9👍75🤝2
👩‍💻 Разберем text Blocks — читаемые и удобные многострочные строки без \n и кавычек!

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

👉 Java Ready | #шпора
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥72👍2
This media is not supported in your browser
VIEW IN TELEGRAM
❤️ Learn Java Spring — структурированная база по Java и Spring!

Репозиторий представляет собой системную подборку материалов для изучения Java и Spring Framework, от базового уровня до продвинутых тем. Внутри есть ссылки на статьи, гайды и туториалы, разбитые по разделам: Core Java, коллекции, многопоточность, build-инструменты, а также Spring и Spring Boot.

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


👉 Java Ready | #репозиторий
Please open Telegram to view this post
VIEW IN TELEGRAM
16👍5🔥4
Как использовать enum вместо списков в Java!

Если логика зависит от фиксированного набора вариантов, не всегда стоит раздувать switch.

Например, сначала код может выглядеть аккуратно:
switch (tariff) {
case PRO -> 10;
case ENTERPRISE -> 20;
default -> 0;
}


Но когда правил становится больше, такой switch часто начинает расползаться по проекту.

Для таких случаев можно использовать EnumMap — это Map, оптимизированная специально под enum-ключи:
var discounts = new EnumMap<Tariff, Integer>(Tariff.class);

discounts.put(Tariff.PRO, 10);
discounts.put(Tariff.ENTERPRISE, 20);


А значение можно доставать без лишних условий:
int discount = discounts.getOrDefault(tariff, 0);


Так код становится проще расширять: добавился новый тариф, добавляешь новое правило, а не ищешь все switch по проекту.

Сохрани, если часто превращаешь enum в длинную цепочку условий!

👉 Java Ready | #совет
Please open Telegram to view this post
VIEW IN TELEGRAM
15👍5🔥4
Как правильно закрывать файлы и соединения!

Когда работаешь с файлами, потоками или подключениями к базе, ресурс нужно закрывать. Если забыть это сделать, приложение может начать держать лишние файлы, память или соединения.

Плохой вариант:
BufferedReader reader = Files.newBufferedReader(path);
String line = reader.readLine();
reader.close();

Если ошибка произойдёт до close(), ресурс может остаться открытым.

Лучше писать так:
try (BufferedReader reader = Files.newBufferedReader(path)) {
String line = reader.readLine();
}

Java сама закроет ресурс после выполнения блока, даже если внутри произойдёт исключение.

Используй try-with-resources для файлов, потоков, сокетов и всего, что реализует AutoCloseable.

👉 Java Ready | #совет
Please open Telegram to view this post
VIEW IN TELEGRAM
9🔥5👍4
😎 Хочешь научиться делать парсер на Java? Тогда эта статья тебе точно понравится!

В ней ты узнаешь:
• Как создать Spring Boot-проект для парсинга данных
• Как получать XML-данные с внешнего источника
• Как сохранять результат в PostgreSQL через Hibernate
• Как разложить проект на нормальные слои: модель, сервис и репозиторий


Продолжай читать на Habr!


👉 Java Ready | #статья
Please open Telegram to view this post
VIEW IN TELEGRAM
9👍4🔥4
😎 Нашёл вам геймифицированный тренажёр по Java!

CodeGym — это онлайн-платформа, где 80% обучения — это практика. Более 1200 задач, игровые уровни и система прокачки помогут освоить Java от нуля до уверенного уровня. Отличный выбор как для новичков, так и для тех, кто хочет прокачаться глубже.

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

👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
8👍3🔥2😁1
Автоматический сервис для проверки доступности сайта!

Хотите быстро сделать мини-мониторинг, который будет проверять сайт и показывать, доступен он или нет? Напишем простой Java-сервис, который отправляет HTTP-запрос и выводит статус ответа.

Импортируем необходимые классы:

import java.net.URI;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;
import java.time.Duration;


Создаём клиент и указываем сайт, который будем проверять:

String url = "https://example.com";

HttpClient client = HttpClient.newBuilder()
.connectTimeout(Duration.ofSeconds(5))
.build();


Формируем GET-запрос с таймаутом, чтобы программа не зависала слишком долго:

HttpRequest request = HttpRequest.newBuilder()
.uri(URI.create(url))
.timeout(Duration.ofSeconds(10))
.GET()
.build();

Отправляем запрос и получаем код ответа от сервера:

HttpResponse<String> response = client.send(
request,
HttpResponse.BodyHandlers.ofString()
);

int statusCode = response.statusCode();

Проверяем статус и выводим понятный результат:

if (statusCode >= 200 && statusCode < 400) {
System.out.println("Сайт доступен: " + statusCode);
} else {
System.out.println("Проблема с сайтом: " + statusCode);
}

Теперь у вас есть простой мониторинг сайта, который можно доработать под уведомления в Telegram, логирование или регулярную проверку по расписанию!

👉 Java Ready | #практика
Please open Telegram to view this post
VIEW IN TELEGRAM
4👍3🔥3
This media is not supported in your browser
VIEW IN TELEGRAM
✍️ Genei — AI-инструмент для ускорения чтения и работы с информацией!

Это нейросеть, ориентированная на работу с текстами и исследованиями: она анализирует статьи, PDF и веб-страницы, автоматически выделяет ключевые идеи и делает краткие выжимки. Сервис помогает быстрее обрабатывать большие объёмы информации и структурировать материалы в удобном виде.

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

👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
👍96🔥5
📂 Базовые компоненты современной сетевой инфраструктуры!

Например, router маршрутизирует трафик между сетями, а load balancer распределяет нагрузку между серверами, повышая отказоустойчивость.

На картинке — основные компоненты сетевой инфраструктуры: от базового networking (DNS, DHCP, NTP) до безопасности (Firewall, VPN, IDS/IPS), доставки трафика (Reverse Proxy, API Gateway) и управления (SIEM, NMS).

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

👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
10🔥6👍5
Знаете, что в Java можно обновлять счётчики в Map без лишних if?

Обычно для таких задач пишут проверку: есть ли ключ, потом отдельно увеличивают значение:
if (stats.containsKey("java")) {
stats.put("java", stats.get("java") + 1);
} else {
stats.put("java", 1);
}


Метод merge делает это короче и безопаснее:
stats.merge("java", 1, Integer::sum);


Если ключа ещё нет Java положит значение 1.

Если ключ уже есть Java возьмёт старое значение и объединит его с новым через функцию:
Integer::sum


То есть при повторном вызове значение просто увеличится:
stats.merge("java", 1, Integer::sum);


Это удобно для подсчёта слов, лайков, событий, ошибок, метрик и любой статистики.

Map.merge() это простой способ писать меньше кода и не плодить ручные проверки.

👉 Java Ready | #совет
Please open Telegram to view this post
VIEW IN TELEGRAM
10👍5🔥3🤝1