📚 Продвинутые методы архивации: LZ77/78
Приглашаем на открытый урок.
🗓 25 июня в 20:00 МСК
🆓 Бесплатно. Урок в рамках старта курса «Алгоритмы и структуры данных».
✔️ На этом вебинаре мы завершим создание архиватора, добавив алгоритм LZ77/78. Разберем принцип словарного сжатия, механизм поиска повторяющихся последовательностей и формат их кодирования.
✔️ Имплементируем выбранный алгоритм и проведем финальное сравнение всех трех методов сжатия (RLE, Huffman, LZ77/78). Определим, какие алгоритмы лучше работают для различных типов файлов и почему.
Завершающее практическое занятие для тех, кто хочет освоить продвинутые алгоритмы и увидеть их применение в реальном проекте.
🎁 Всем участникам вебинара дарим промокод, который дает скидку на обучение - Algo5
👉 Регистрация на вебинар: https://vk.cc/cMXtZN
Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
Приглашаем на открытый урок.
🗓 25 июня в 20:00 МСК
🆓 Бесплатно. Урок в рамках старта курса «Алгоритмы и структуры данных».
Завершающее практическое занятие для тех, кто хочет освоить продвинутые алгоритмы и увидеть их применение в реальном проекте.
Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
Please open Telegram to view this post
VIEW IN TELEGRAM
❤2
This media is not supported in your browser
VIEW IN TELEGRAM
This media is not supported in your browser
VIEW IN TELEGRAM
This media is not supported in your browser
VIEW IN TELEGRAM
This media is not supported in your browser
VIEW IN TELEGRAM
This media is not supported in your browser
VIEW IN TELEGRAM
This media is not supported in your browser
VIEW IN TELEGRAM
This media is not supported in your browser
VIEW IN TELEGRAM
This media is not supported in your browser
VIEW IN TELEGRAM
This media is not supported in your browser
VIEW IN TELEGRAM
This media is not supported in your browser
VIEW IN TELEGRAM
Вопросы-ответы собеседования
Можно ли создать экземпляр абстрактного класса?
Что такое интерфейс?
Как вызвать нестатический метод в статическом?
Чем отличаются параметры от аргументов в методе?
Что такое конструктор? Как его создать и вызвать?
Что такое параметризованный конструктор?
Что такое конструктор по умолчанию?
Что такое приватный конструктор? Зачем он закрытый?
Что такое статическая переменная? Как работает static поле?
Что такое статический метод? Как вызвать static метод?
источник
👉@BookJava
Можно ли создать экземпляр абстрактного класса?
Что такое интерфейс?
Как вызвать нестатический метод в статическом?
Чем отличаются параметры от аргументов в методе?
Что такое конструктор? Как его создать и вызвать?
Что такое параметризованный конструктор?
Что такое конструктор по умолчанию?
Что такое приватный конструктор? Зачем он закрытый?
Что такое статическая переменная? Как работает static поле?
Что такое статический метод? Как вызвать static метод?
источник
👉@BookJava
👍7❤1
💡 Почему в
Когда используешь
1. ❌ Нельзя добавлять дубликаты
2. ❌ Нельзя добавлять
Разбираемся, почему так:
🔐
Метод
* После создания ты не можешь изменить его (добавить, удалить элемент).
* Все элементы внутри должны быть уникальны и не должны быть
📛 Почему нельзя дубликаты?
Потому что
А
Это сделано для того, чтобы не было тихих ошибок — чтобы ты сразу увидел, что передал неуникальные значения.
🕳️ Почему нельзя
Это сделано сознательно —
👀 Хочешь изменяемый
👉@BookJava
Set.of()
в Java нельзя добавить дубликаты и null
?Когда используешь
Set.of(...)
, можно столкнуться с двумя неожиданностями:1. ❌ Нельзя добавлять дубликаты
2. ❌ Нельзя добавлять
null
Разбираемся, почему так:
🔐
Set.of(...)
— это immutable SetМетод
Set.of(...)
, добавленный в Java 9, создаёт неизменяемое множество. Это значит:* После создания ты не можешь изменить его (добавить, удалить элемент).
* Все элементы внутри должны быть уникальны и не должны быть
null
.📛 Почему нельзя дубликаты?
Потому что
Set
по определению — это коллекция уникальных элементов.А
Set.of(...)
бросает IllegalArgumentException
, сразу во время создания, если переданы дубликаты:
Set.of("a", "b", "a"); // 💥 Бросит исключение!
Это сделано для того, чтобы не было тихих ошибок — чтобы ты сразу увидел, что передал неуникальные значения.
🕳️ Почему нельзя
null
?Set.of(...)
не принимает null
, потому что он реализован через внутренние immutable структуры, которые не допускают null`-значений. При попытке добавить `null
получишь NullPointerException
.
Set.of("a", null); // 💥 NullPointerException
Это сделано сознательно —
null
может вести к неочевидным багам и плохо сочетается с концепцией неизменяемых коллекций.👀 Хочешь изменяемый
Set
, который принимает null
и дубликаты фильтрует сам? Используй HashSet
:
Set<String> set = new HashSet<>();
set.add(null); // ✅ Можно
👉@BookJava
👍4🤔3
🤯 🤯 🤯 Параллелизм в многопоточном Java-коде создаёт новые проблемы в тестировании, а баги остаются незамеченными?
⚡️ Приглашаем на открытый вебинар «Юнит тесты для многопоточного кода»
24 июня в 20:00 МСК.
На вебинаре мы разберём:
✔️ Как обнаружить гонки, дедлоки и нестабильность в многопоточном коде.
✔️ Как использовать argumentCaptor и spy для проверки взаимодействия потоков.
✔️ Эмуляцию задержек и таймингов с помощью AdditionalAnswers.
🦾 После урока вы будете уверенно писать стабильные unit-тесты для многопоточного кода, выявлять скрытые баги и улучшать качество тестирования.
Открытый урок проходит в преддверии старта курса «Java Developer. Advanced».
Все участники получат скидку на обучение.
🔗 Регистрируйтесь прямо сейчас: https://vk.cc/cMZNzb
Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
24 июня в 20:00 МСК.
На вебинаре мы разберём:
Открытый урок проходит в преддверии старта курса «Java Developer. Advanced».
Все участники получат скидку на обучение.
🔗 Регистрируйтесь прямо сейчас: https://vk.cc/cMZNzb
Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
Please open Telegram to view this post
VIEW IN TELEGRAM
🧠 Трюк с
Когда ты используешь
📌 Пример:
Если
⚠️ Это особенно критично, если ты триггеришь событие в
💡 Как избежать:
1. Используй явное управление порядком инициализации через
2. Не публикуй события слишком рано — лучше в
🧵 Альтернатива: если тебе нужно гарантированное выполнение в момент старта — лучше использовать
👉@BookJava
@EventListener
в Spring Boot — неочевидная ловушкаКогда ты используешь
@EventListener
для обработки событий в Spring, ты можешь попасть в баг, который очень сложно отловить в бою — пропущенные события.📌 Пример:
@Component
public class MyListener {
@EventListener
public void on(MyEvent event) {
// логика
}
}
Если
MyListener
бин ещё не проинициализирован, а событие уже публикуется (ApplicationEventPublisher#publishEvent
), то метод on
просто не будет вызван. Spring не будет "накапливать" события для будущих слушателей.⚠️ Это особенно критично, если ты триггеришь событие в
@PostConstruct
или в CommandLineRunner
, а слушатель находится в другом бине, который ещё не загружен.💡 Как избежать:
1. Используй явное управление порядком инициализации через
@DependsOn
.2. Не публикуй события слишком рано — лучше в
ApplicationReadyEvent
:
@Component
public class Publisher {
private final ApplicationEventPublisher publisher;
public Publisher(ApplicationEventPublisher publisher) {
this.publisher = publisher;
}
@EventListener(ApplicationReadyEvent.class)
public void onReady() {
publisher.publishEvent(new MyEvent(this));
}
}
🧵 Альтернатива: если тебе нужно гарантированное выполнение в момент старта — лучше использовать
ApplicationRunner
или InitializingBean
, где порядок можно контролировать проще.👉@BookJava
👍6
Совет 💡
Если вы хотите получить сообщение о первопричине, вы можете легко и безопасно получить его с помощью
👉@BookJava
Если вы хотите получить сообщение о первопричине, вы можете легко и безопасно получить его с помощью
Apache Commons ExceptionUtils
. Методы getRootCauseMessage(Exception ex)
выдают сообщение в виде {ClassNameWithoutPackage} {ThrowableMessage}
👉@BookJava
👍7💩1
Когда системы не хотят «дружить» между собой — начинается головная боль.😫
Особенно если речь идет о масштабировании и автоматизации процессов. Как избежать лишнего кода, сэкономить время и силы, при этом интегрировать внешние системы с Apache Kafka?
Ответ — Kafka Connect.
Записывайтесь на открытый вебинар, где мы разберем, как решить типичные проблемы интеграции и масштабирования.
Что будет на вебинаре:
✒️Основы Kafka Connect: Архитектура и принципы работы, коннекторы
✒️Практическая реализация: Настройка и запуск коннекторов для интеграции с базами данных и файловыми системами
✒️Ошибки и их решение: Как эффективно отлаживать и масштабировать Kafka Connect
23 июня в 19:00 (МСК) — Бесплатно!
Спикер: Валентин Шилин — Старший программист и аналитик данных в Deutsche Telekom IT GmbH
Дарим чек-лист по установке Kafka Connect при регистрации на вебинар!
Присоединяйтесь, если хотите научиться упрощать сложные задачи и увеличивать надежность своих систем: https://tglink.io/88d34f764ba1
Реклама. ООО "ОТУС ОНЛАЙН-ОБРАЗОВАНИЕ". ИНН 9705100963. erid: 2W5zFH5vcGg
Особенно если речь идет о масштабировании и автоматизации процессов. Как избежать лишнего кода, сэкономить время и силы, при этом интегрировать внешние системы с Apache Kafka?
Ответ — Kafka Connect.
Записывайтесь на открытый вебинар, где мы разберем, как решить типичные проблемы интеграции и масштабирования.
Что будет на вебинаре:
✒️Основы Kafka Connect: Архитектура и принципы работы, коннекторы
✒️Практическая реализация: Настройка и запуск коннекторов для интеграции с базами данных и файловыми системами
✒️Ошибки и их решение: Как эффективно отлаживать и масштабировать Kafka Connect
23 июня в 19:00 (МСК) — Бесплатно!
Спикер: Валентин Шилин — Старший программист и аналитик данных в Deutsche Telekom IT GmbH
Дарим чек-лист по установке Kafka Connect при регистрации на вебинар!
Присоединяйтесь, если хотите научиться упрощать сложные задачи и увеличивать надежность своих систем: https://tglink.io/88d34f764ba1
Реклама. ООО "ОТУС ОНЛАЙН-ОБРАЗОВАНИЕ". ИНН 9705100963. erid: 2W5zFH5vcGg
👍2
🧠 Spring Boot + MapStruct: как избежать
При обновлении сущностей через MapStruct бывает типичная проблема: маппер затирает уже существующие поля
Допустим, у нас есть:
И сущность:
Если ты используешь обычный
— не переданное поле
📌 Чтобы этого не происходило, добавь в маппер:
💡
⚠️ Это работает только для объектов, не для
Такой подход позволяет обновлять только те поля, которые реально пришли, и не бояться случайного затирания.
👉@BookJava
null
при обновлении сущностиПри обновлении сущностей через MapStruct бывает типичная проблема: маппер затирает уже существующие поля
null'ами
, если они не переданы во входном DTO. Это может легко привести к потере данных. Покажу, как решить это изящно.Допустим, у нас есть:
public class UserDto {
private String name;
private String email;
}
И сущность:
@Entity
public class User {
private String name;
private String email;
}
Если ты используешь обычный
@MappingTarget
, то:
@MappingTarget User user, UserDto dto
— не переданное поле
email
в dto
затирает значение в user
.📌 Чтобы этого не происходило, добавь в маппер:
@Mapper(nullValuePropertyMappingStrategy = NullValuePropertyMappingStrategy.IGNORE)
public interface UserMapper {
void update(@MappingTarget User user, UserDto dto);
}
💡
NullValuePropertyMappingStrategy.IGNORE
говорит MapStruct: не трогай те поля, которые в DTO пришли как null
.⚠️ Это работает только для объектов, не для
Optional
и не для примитивов. Там потребуется другая стратегия — например, обёртки или @Condition
.Такой подход позволяет обновлять только те поля, которые реально пришли, и не бояться случайного затирания.
👉@BookJava
👍5❤4
Media is too big
VIEW IN TELEGRAM
Создание REST API с использованием Spring WebFlux и Security
00:00:00 Введение
00:00:20 Создание проекта
00:11:36 Создание миграций БД
00:15:40 Создание базовых классов
00:23:20 Реализация логики генерации JWT токена
00:46:30 Реализация логики валидации JWT токена
00:53:05 Построения цепочки аутентификации
01:04:22 Финальная конфигурация с использованием SecurityWebFilterChain
01:12:11 Реализация REST контроллеров
01:23:15 Проверка REST API средствами Postman
01:24:21 Добавление и конфигурация обработчика ошибок
01:25:40 Заключение
Ссылка на Github репозиторий https://github.com/proselytear/webfluxsecurity
источник
👉@BookJava
00:00:00 Введение
00:00:20 Создание проекта
00:11:36 Создание миграций БД
00:15:40 Создание базовых классов
00:23:20 Реализация логики генерации JWT токена
00:46:30 Реализация логики валидации JWT токена
00:53:05 Построения цепочки аутентификации
01:04:22 Финальная конфигурация с использованием SecurityWebFilterChain
01:12:11 Реализация REST контроллеров
01:23:15 Проверка REST API средствами Postman
01:24:21 Добавление и конфигурация обработчика ошибок
01:25:40 Заключение
Ссылка на Github репозиторий https://github.com/proselytear/webfluxsecurity
источник
👉@BookJava
👍6🔥1
👩💻🎯 Юнитесты на Java: как новичку поймать баги за 5 Секунд?
Приглашаем на открытый урок.
🗓 25 июня в 20:00 МСК
🆓 Бесплатно. Урок в рамках старта курса «Java-разработчик».
🦾 Тестирование — суперсила разработчика. Научитесь писать код, который проверяет сам себя, экономит часы на отладке и делает ваши приложения неуязвимыми.
О чём поговорим:
✔️ Что такое Unit-тесты? Для чего они нужны, даже если «код и так работает».
✔️ JUnit 5 для новичков: как установить и написать первый тест.
✔️ Тестирование = Дзен-кодинг: как тесты помогают понять свой код лучше вас самих.
✔️ Ловушки и лайфхаки: что делать, если тесты падают?
Кому будет интересно:
Начинающим Java-разработчикам, студентам и всем, кто хочет перестать бояться слов «тестирование» и «баги».
В результате вебинара вы:
Создадите свой первый тест на Java, поймёте, как тестировать методы с исключениями, и начнёте писать код, которым можно гордиться.
🔗 Ссылка на регистрацию: https://vk.cc/cN4MxX
Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
Приглашаем на открытый урок.
🗓 25 июня в 20:00 МСК
🆓 Бесплатно. Урок в рамках старта курса «Java-разработчик».
О чём поговорим:
Кому будет интересно:
Начинающим Java-разработчикам, студентам и всем, кто хочет перестать бояться слов «тестирование» и «баги».
В результате вебинара вы:
Создадите свой первый тест на Java, поймёте, как тестировать методы с исключениями, и начнёте писать код, которым можно гордиться.
🔗 Ссылка на регистрацию: https://vk.cc/cN4MxX
Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
Please open Telegram to view this post
VIEW IN TELEGRAM
❤2
💡 Совет Java
✅ Заменяем и переворачиваем последнее слово в строке — без использования StringBuilder!
Когда-нибудь задумывался, как в Java перевернуть только последнее слово в предложении и вставить его обратно? 🤔
Вот лаконичное решение на чистом Java, без использования
💡 Отлично подойдёт новичкам, чтобы лучше понять:
1. Логику реверса строки 🔁
2. Работу с массивами и циклами 🧩
3. Почему важно избегать изменяемых классов, вроде StringBuilder, когда тренируешь основы 💪
👉@BookJava
✅ Заменяем и переворачиваем последнее слово в строке — без использования StringBuilder!
Когда-нибудь задумывался, как в Java перевернуть только последнее слово в предложении и вставить его обратно? 🤔
Вот лаконичное решение на чистом Java, без использования
StringBuilder
.💡 Отлично подойдёт новичкам, чтобы лучше понять:
1. Логику реверса строки 🔁
2. Работу с массивами и циклами 🧩
3. Почему важно избегать изменяемых классов, вроде StringBuilder, когда тренируешь основы 💪
👉@BookJava
👎8👍1💩1
🚀 7 самых полезных методов Stream API в Java 21
Работаешь с коллекциями в Java? Тогда Stream API — твой лучший друг. В Java 21 он стал ещё удобнее. Вот краткая шпаргалка по самым нужным методам — с понятными примерами 👇
🔹 1. filter(Predicate)
📌 Фильтрует элементы по условию.
🧠 Пример: оставить только чётные числа:
🔹 2. map(Function)
📌 Преобразует каждый элемент.
🧠 Пример: сделать все имена заглавными:
🔹 3. flatMap(Function)
📌 «Сплющивает» вложенные коллекции.
🧠 Пример: объединить вложенные списки:
🔹 4. collect(Collector)
📌 Собирает элементы в коллекцию.
🧠 Пример: получить Set из списка:
🔹 5. forEach(Consumer)
📌 Выполняет действие для каждого элемента.
🧠 Пример: распечатать все имена:
🔹 6. reduce(BinaryOperator)
📌 Сводит все элементы к одному значению.
🧠 Пример: сумма чисел:
🔹 7. takeWhile / dropWhile (Java 9+)
📌 Берёт или пропускает элементы, пока выполняется условие.
🧠 Пример: взять только числа < 10:
💡 Лайфхак: вместо
👇 А ты какие методы используешь чаще всего? Поделись в комментах — реальный опыт всегда круче теории!
👉@BookJava
Работаешь с коллекциями в Java? Тогда Stream API — твой лучший друг. В Java 21 он стал ещё удобнее. Вот краткая шпаргалка по самым нужным методам — с понятными примерами 👇
🔹 1. filter(Predicate)
📌 Фильтрует элементы по условию.
🧠 Пример: оставить только чётные числа:
List<Integer> evens = numbers.stream()
.filter(n -> n % 2 == 0)
.toList();
🔹 2. map(Function)
📌 Преобразует каждый элемент.
🧠 Пример: сделать все имена заглавными:
List<String> upperCaseNames = names.stream()
.map(String::toUpperCase)
.toList();
🔹 3. flatMap(Function)
📌 «Сплющивает» вложенные коллекции.
🧠 Пример: объединить вложенные списки:
List<String> words = nestedLists.stream()
.flatMap(List::stream)
.toList();
🔹 4. collect(Collector)
📌 Собирает элементы в коллекцию.
🧠 Пример: получить Set из списка:
Set<String> uniqueNames = names.stream()
.collect(Collectors.toSet());
🔹 5. forEach(Consumer)
📌 Выполняет действие для каждого элемента.
🧠 Пример: распечатать все имена:
names.stream().forEach(System.out::println);
🔹 6. reduce(BinaryOperator)
📌 Сводит все элементы к одному значению.
🧠 Пример: сумма чисел:
int sum = numbers.stream()
.reduce(0, Integer::sum);
🔹 7. takeWhile / dropWhile (Java 9+)
📌 Берёт или пропускает элементы, пока выполняется условие.
🧠 Пример: взять только числа < 10:
List<Integer> lessThanTen = numbers.stream()
.takeWhile(n -> n < 10)
.toList();
💡 Лайфхак: вместо
collect(...)
используй toList()
и toSet()
— код станет чище, а производительность выше.👇 А ты какие методы используешь чаще всего? Поделись в комментах — реальный опыт всегда круче теории!
👉@BookJava
👍3👎3💩3