Вместо скрытых проверок и неожиданных NullPointerException код становится явным: значение либо есть, либо его нет. Это упрощает чтение логики и уменьшает количество защитных условий.
Правильное использование Optional делает API понятнее и безопаснее. Метод сразу показывает, что результат может отсутствовать, а цепочка вызовов позволяет обрабатывать этот случай аккуратно.Please open Telegram to view this post
VIEW IN TELEGRAM
❤11🔥7👍6🤝3
This media is not supported in your browser
VIEW IN TELEGRAM
Это обучающий портал, где подробно разобраны синтаксис, ООП, коллекции, исключения, потоки ввода-вывода, многопоточность и другое. Материал подаётся структурированно, от основ языка до продвинутых тем и API. Почти в каждом разделе есть примеры кода, объяснение концепций и ссылки на официальную документацию.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤11👍10🔥7
Timeout wrapper для операций!
Иногда операция может зависнуть, чтобы программа не ждала бесконечно, можно задать таймаут выполнения.
Если задача не успела она прерывается и возвращается ошибка.
Создаём пул потоков для выполнения задач:
Оборачиваем операцию в Future:
Пытаемся получить результат с таймаутом:
Если время вышло прерываем задачу:
Не забываем завершить пул потоков:
Теперь любая операция может выполняться с ограничением по времени.
👉 Java Ready | #практика
Иногда операция может зависнуть, чтобы программа не ждала бесконечно, можно задать таймаут выполнения.
Если задача не успела она прерывается и возвращается ошибка.
Создаём пул потоков для выполнения задач:
var pool = java.util.concurrent.Executors.newSingleThreadExecutor();
Оборачиваем операцию в Future:
var future = pool.submit(() -> {
Thread.sleep(2000); // имитация долгой операции
return "Готово";
});Пытаемся получить результат с таймаутом:
try {
var result = future.get(1, java.util.concurrent.TimeUnit.SECONDS);
System.out.println(result);
}Если время вышло прерываем задачу:
catch (java.util.concurrent.TimeoutException e) {
future.cancel(true);
System.out.println("Операция превысила лимит времени");
}Не забываем завершить пул потоков:
pool.shutdown();
Теперь любая операция может выполняться с ограничением по времени.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤8👍4🔥4
Выявление мошеннических транзакций с помощью ML!
Детекция мошеннических операций — одна из основных задач финтех-систем. Модель должна оценивать риск транзакции и выявлять подозрительную активность в потоке платежей.
Установка библиотек:
Будем использовать pandas для работы с данными и scikit-learn для построения модели.
Импорт модулей:
Мы будем использовать пайплайн, который объединяет предобработку и модель — это стандартная практика для воспроизводимости и предотвращения утечек данных.
Пример структуры данных (учебный):
Признаки отражают типичные сигналы риска: сумма операции, время суток, зарубежная транзакция и активность аккаунта за последние сутки. Целевая переменная
Разделим данные на признаки и целевую переменную:
Теперь модель будет учиться предсказывать
Разделим данные на обучающую и тестовую выборки:
Стратификация сохраняет долю мошеннических операций в обеих выборках, что особенно важно при дисбалансе классов.
В антифроде логистическая регрессия часто используется как базовая модель: она быстрая, понятная и умеет оценивать вероятность мошенничества. Чтобы учесть дисбаланс классов, зададим веса.
Обучим модель в составе пайплайна:
Оценка качества модели:
Отчёт показывает
Пример оценки новой транзакции:
Модель возвращает вероятность
🔥 В настоящих системах такие модели работают в режиме реального времени: вероятность риска влияет на блокировку операции, запрос дополнительной аутентификации или передачу транзакции на ручную проверку.
👉 Java Ready | #практика
Детекция мошеннических операций — одна из основных задач финтех-систем. Модель должна оценивать риск транзакции и выявлять подозрительную активность в потоке платежей.
Установка библиотек:
pip install pandas scikit-learn
Будем использовать pandas для работы с данными и scikit-learn для построения модели.
Импорт модулей:
import pandas as pd
from sklearn.model_selection import train_test_split
from sklearn.pipeline import Pipeline
from sklearn.preprocessing import StandardScaler
from sklearn.linear_model import LogisticRegression
from sklearn.metrics import classification_report
Мы будем использовать пайплайн, который объединяет предобработку и модель — это стандартная практика для воспроизводимости и предотвращения утечек данных.
Пример структуры данных (учебный):
data = pd.DataFrame({
"amount": [12, 35, 60, 15, 22, 40, 2500, 4200, 5000, 3600],
"hour": [14, 18, 12, 10, 16, 19, 3, 2, 1, 2],
"is_foreign": [0, 0, 0, 0, 0, 0, 1, 1, 1, 1],
"transactions_last_24h": [2, 3, 1, 2, 2, 3, 15, 20, 25, 18],
"fraud": [0, 0, 0, 0, 0, 0, 1, 1, 1, 1]
})Признаки отражают типичные сигналы риска: сумма операции, время суток, зарубежная транзакция и активность аккаунта за последние сутки. Целевая переменная
fraud показывает, признана ли операция мошеннической.Разделим данные на признаки и целевую переменную:
X = data.drop(columns=["fraud"])
y = data["fraud"]
Теперь модель будет учиться предсказывать
fraud на основе остальных признаков.Разделим данные на обучающую и тестовую выборки:
X_train, X_test, y_train, y_test = train_test_split(
X, y, test_size=0.3, random_state=42, stratify=y
)
Стратификация сохраняет долю мошеннических операций в обеих выборках, что особенно важно при дисбалансе классов.
В антифроде логистическая регрессия часто используется как базовая модель: она быстрая, понятная и умеет оценивать вероятность мошенничества. Чтобы учесть дисбаланс классов, зададим веса.
Обучим модель в составе пайплайна:
model = Pipeline(steps=[
("scaler", StandardScaler()),
("clf", LogisticRegression(max_iter=1000, class_weight="balanced"))
])
model.fit(X_train, y_train)
StandardScaler нормализует числовые признаки, что улучшает сходимость линейных моделей.Оценка качества модели:
y_pred = model.predict(X_test)
print(classification_report(y_test, y_pred))
Отчёт показывает
precision, recall и F1-меру для каждого класса. На малых данных, метрики приведены исключительно в демонстрационных целях.Пример оценки новой транзакции:
tx = pd.DataFrame([{
"amount": 3200,
"hour": 2,
"is_foreign": 1,
"transactions_last_24h": 18
}])
risk = model.predict_proba(tx)[0][1]
print("Вероятность мошенничества:", round(risk, 2))Модель возвращает вероятность
fraud, которую можно использовать для принятия решения.Please open Telegram to view this post
VIEW IN TELEGRAM
❤10👍7👎5🔥5😁1
Например, ArrayList используется для динамических массивов и быстрого доступа по индексу, а HashSet позволяет хранить только уникальные элементы без повторений.
На картинке — иерархия основных интерфейсов и реализаций Java-коллекций. Такая схема помогает быстро вспомнить, какая структура данных подходит для конкретной задачи.
Сохрани, чтобы не забыть!
Please open Telegram to view this post
VIEW IN TELEGRAM
❤12👍9🔥6
Он позволяет обходить коллекции и при необходимости делить их на части для параллельной обработки. Это делает работу Stream API эффективной и масштабируемой, особенно при обработке больших наборов данных.
Понимание Spliterator помогает лучше разобраться в том, как Java оптимизирует итерацию и распределяет задачи между потоками. Даже если вы используете только Stream API, именно этот интерфейс выполняет основную работу под капотом.Please open Telegram to view this post
VIEW IN TELEGRAM
🔥11❤4👍4
This media is not supported in your browser
VIEW IN TELEGRAM
Это крупное сообщество, где ежедневно публикуются статьи, разборы технологий, туториалы и примеры кода по Java и связанному стеку. Портал ориентирован на программистов разных уровней. Помимо статей, на портале есть полноценные обучающие разделы. Это делает сайт удобным как для обучения, так и для регулярного чтения, чтобы быть в курсе новостей языка.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥8❤7👍5🤝2
На иллюстрации показано, как оба языка обрабатывают код: от редактора и компиляции до выполнения программы.
Python использует интерпретатор и виртуальную машину PVM, а Java — компилятор javac, байткод и JVM с JIT-компиляцией.
Сохрани, чтобы не забыть!
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥8👍6❤5
Например, DNS отвечает за преобразование доменных имен в IP-адреса, TCP обеспечивает надежное соединение и порядок доставки пакетов, а HTTP используется для обмена запросами и ответами между клиентом и сервером.
На картинке — основные сетевые протоколы и уровни, которые участвуют в передаче данных.
Сохрани, чтобы не потерять!
Please open Telegram to view this post
VIEW IN TELEGRAM
❤8🔥8👍6
Перечитывание конфигов без рестарта!
Сделаем простой reload: читаем .properties и обновляем значения в памяти.
Указываем путь к конфиг-файлу:
Функция загрузки настроек из файла:
Читаем конкретный параметр из конфига:
Перезагружаем конфиг в любой момент:
Пример файла
Теперь настройки можно менять прямо в файле, не перезапуская приложение. Достаточно вызвать load() и новые значения сразу применятся. Так работают динамические конфиги в реальных сервисах.
👉 Java Ready | #практика
Сделаем простой reload: читаем .properties и обновляем значения в памяти.
Указываем путь к конфиг-файлу:
var path = java.nio.file.Path.of("config.properties");
var props = new java.util.Properties();Функция загрузки настроек из файла:
void load() throws Exception {
try (var in = java.nio.file.Files.newInputStream(path)) {
props.clear();
props.load(in);
}
}Читаем конкретный параметр из конфига:
String get(String key) {
return props.getProperty(key);
}Перезагружаем конфиг в любой момент:
load();
System.out.println("port=" + get("server.port"));
Пример файла
config.properties:server.port=8080
feature.newLogin=true
limit.requests=100
Теперь настройки можно менять прямо в файле, не перезапуская приложение. Достаточно вызвать load() и новые значения сразу применятся. Так работают динамические конфиги в реальных сервисах.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤9👍4🔥4
Чат по локальной сети
Создаём самый простой вариант чат, один компьютер запускает сервер, второй клиент, и они обмениваются сообщениями по Socket.
Сервер ждёт подключение:
Клиент подключается по IP:
Читаем сообщения от собеседника:
Отправляем свои сообщения:
Чтобы чат работал постоянно, один поток читает, второй пишет:
Основной поток отправляет то, что вводишь в консоль:
В итоге получается уже настоящий чат по локалке,
один ПК запускает сервер, второй подключается по IP, и сообщения ходят в обе стороны в реальном времени.
👉 Java Ready | #совет
Создаём самый простой вариант чат, один компьютер запускает сервер, второй клиент, и они обмениваются сообщениями по Socket.
Сервер ждёт подключение:
ServerSocket server = new ServerSocket(5000);
Socket socket = server.accept();
System.out.println("Клиент подключился");
Клиент подключается по IP:
Socket socket = new Socket("192.168.0.10", 5000);
System.out.println("Подключено к серверу");Читаем сообщения от собеседника:
BufferedReader in = new BufferedReader(
new InputStreamReader(socket.getInputStream())
);
Отправляем свои сообщения:
PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
out.println("Привет из клиента!");
Чтобы чат работал постоянно, один поток читает, второй пишет:
new Thread(() -> {
while (true) System.out.println(in.readLine());
}).start();Основной поток отправляет то, что вводишь в консоль:
Scanner sc = new Scanner(System.in);
while (true) out.println(sc.nextLine());
В итоге получается уже настоящий чат по локалке,
один ПК запускает сервер, второй подключается по IP, и сообщения ходят в обе стороны в реальном времени.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤12🔥8👍5
This media is not supported in your browser
VIEW IN TELEGRAM
Perplexity — AI-поисковик с генеративной моделью и встроенным web-ресёрчем. Работает по RAG-архитектуре: ищет актуальные источники, ранжирует их и формирует синтезированный ответ с цитированием. Подходит для быстрого ресёрча, конкурентного анализа, сравнения решений и проверки гипотез на основе свежих данных.
📌 Оставляю ссылочку: perplexity.ai
👉 Java Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
👍9❤8🔥6