👀 Datafaker
Datafaker создает фиктивные данные для ваших программ JVM за считанные минуты, используя широкий спектр из более чем 100 поставщиков данных.
🗣️ Это может быть очень полезно при генерации тестовых данных для заполнения базы данных, генерации данных для стресс‑теста или анонимизации данных из производственных сервисов. Давайте включим его в наши зависимости.
🔗 Ссылочка на доку (https://www.datafaker.net/documentation/getting-started/)
👩💻
@javaquiz
Datafaker создает фиктивные данные для ваших программ JVM за считанные минуты, используя широкий спектр из более чем 100 поставщиков данных.
🗣️ Это может быть очень полезно при генерации тестовых данных для заполнения базы данных, генерации данных для стресс‑теста или анонимизации данных из производственных сервисов. Давайте включим его в наши зависимости.
🔗 Ссылочка на доку (https://www.datafaker.net/documentation/getting-started/)
👩💻
@javaquiz
➡️ Обработка CloneNotSupportedException и возврат экземпляра подкласса
Несмотря на критику функции клонирования объектов в Java, если вам нужно реализовать метод clone(), вот несколько лучших практик для упрощения задачи:
public Course clone() {
Course c = null;
try {
c = (Course)super.clone();
} catch (CloneNotSupportedException e) {} // Не произойдет
return c;
}
🗣️ Этот код использует тот факт, что метод clone() не вызовет CloneNotSupportedException, если класс реализует интерфейс Cloneable. Возврат подкласса называется ковариантным переопределением методов и доступен с Java 5, что позволяет избежать приведения типа на стороне клиента:
Course javaBeginners = new Course("Java", 100, 10);
Course clone = javaBeginners.clone();
Ранее, например, с классом Date, нужно было явно приводить результат метода clone():
Date d = new Date();
Date clone = (Date) d.clone();
👩💻
@javaquiz
Несмотря на критику функции клонирования объектов в Java, если вам нужно реализовать метод clone(), вот несколько лучших практик для упрощения задачи:
public Course clone() {
Course c = null;
try {
c = (Course)super.clone();
} catch (CloneNotSupportedException e) {} // Не произойдет
return c;
}
🗣️ Этот код использует тот факт, что метод clone() не вызовет CloneNotSupportedException, если класс реализует интерфейс Cloneable. Возврат подкласса называется ковариантным переопределением методов и доступен с Java 5, что позволяет избежать приведения типа на стороне клиента:
Course javaBeginners = new Course("Java", 100, 10);
Course clone = javaBeginners.clone();
Ранее, например, с классом Date, нужно было явно приводить результат метода clone():
Date d = new Date();
Date clone = (Date) d.clone();
👩💻
@javaquiz
⚡️Узнайте, как проектировать бизнес-ориентированные приложения с помощью Domain-Driven Design!
🔥27 мая в 20:00 мск приглашаем на бесплатный вебинар «Практикум проектирования приложения с помощью DDD», где вы на практике разберёте:
– что такое Domain-Driven Design и когда он действительно работает;
– как выделять Bounded Context'ы и формировать Ubiquitous Language;
– как строить архитектуру вокруг предметной области;
– как проектировать API и интерфейсы, опираясь на модель;
– и какие ошибки чаще всего допускают при внедрении DDD в командах.
🛠 В реальном времени спроектируем приложение по DDD на живом кейсе — от концепции до архитектурных решений.
👉Регистрация: https://clck.ru/3MDZvL
Занятие приурочено к старту курса «Архитектура и шаблоны проектирования», где вы глубже освоите DDD, CQRS, Event Storming и другие архитектурные практики.
Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
🔥27 мая в 20:00 мск приглашаем на бесплатный вебинар «Практикум проектирования приложения с помощью DDD», где вы на практике разберёте:
– что такое Domain-Driven Design и когда он действительно работает;
– как выделять Bounded Context'ы и формировать Ubiquitous Language;
– как строить архитектуру вокруг предметной области;
– как проектировать API и интерфейсы, опираясь на модель;
– и какие ошибки чаще всего допускают при внедрении DDD в командах.
🛠 В реальном времени спроектируем приложение по DDD на живом кейсе — от концепции до архитектурных решений.
👉Регистрация: https://clck.ru/3MDZvL
Занятие приурочено к старту курса «Архитектура и шаблоны проектирования», где вы глубже освоите DDD, CQRS, Event Storming и другие архитектурные практики.
Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
Изучите различные модели взаимодействия между микросервисами и выберите оптимальный подход для вашего проекта
Приглашаем на открытый урок.
🗓 28 мая в 20:00 МСК
🆓 Бесплатно. Урок в рамках старта курса «Software Architect».
На вебинаре вы узнаете:
Вебинар будет полезен:
- Разработчикам, работающим с микросервисной архитектурой.
- Архитекторам ПО, стремящимся оптимизировать межсервисное взаимодействие.
- Backend и Fullstack разработчикам, заинтересованным в улучшении взаимодействия между сервисами.
- DevOps-инженерам, отвечающим за развертывание и управление микросервисами.
Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
Please open Telegram to view this post
VIEW IN TELEGRAM
➡️ Использование Iterator для перебора List
В Java есть несколько способов перебрать список: цикл for с индексом, расширенный for и Iterator. Раньше я использовал цикл for с методом get(), как показано ниже:
for (int i = 0; i < list.size(); i++) {
String name = list.get(i);
}
🗣️ Этот метод работает для ArrayList, но если список — это LinkedList или другая реализация без поддержки случайного доступа, время выполнения увеличится до O(N^2), потому что get() для LinkedList имеет O(n) сложность.
Кроме того, при использовании циклов может возникнуть ошибка в многопоточном режиме, например, при работе с CopyOnWriteArrayList, когда один поток изменяет список, а другой пытается получить доступ к элементам, что может привести к IndexOutOfBoundsException.
✔️ Лучше использовать Iterator, который является стандартным способом перебора списка:
Iterator itr = list.iterator();
while (itr.hasNext()) {
String name = itr.next();
}
Это безопаснее и предотвращает непредсказуемое поведение.
👩💻
@javaquiz
В Java есть несколько способов перебрать список: цикл for с индексом, расширенный for и Iterator. Раньше я использовал цикл for с методом get(), как показано ниже:
for (int i = 0; i < list.size(); i++) {
String name = list.get(i);
}
🗣️ Этот метод работает для ArrayList, но если список — это LinkedList или другая реализация без поддержки случайного доступа, время выполнения увеличится до O(N^2), потому что get() для LinkedList имеет O(n) сложность.
Кроме того, при использовании циклов может возникнуть ошибка в многопоточном режиме, например, при работе с CopyOnWriteArrayList, когда один поток изменяет список, а другой пытается получить доступ к элементам, что может привести к IndexOutOfBoundsException.
✔️ Лучше использовать Iterator, который является стандартным способом перебора списка:
Iterator itr = list.iterator();
while (itr.hasNext()) {
String name = itr.next();
}
Это безопаснее и предотвращает непредсказуемое поведение.
👩💻
@javaquiz
➡️ Maven
Maven — один из трёх самых популярных инструментов для сборки проектов на Java. Он отвечает за компиляцию, создание jar-файлов (Java-архивов), создание дистрибутива программы, генерацию документации.
🗣️ Maven — просто отличная штука, хоть поначалу и не очень понятная. Если вы никогда не использовали Maven раньше, вы многое потеряли.
🔗 Ссылочка на доку (https://maven.apache.org/guides/index.html)
👩💻
@javaquiz
Maven — один из трёх самых популярных инструментов для сборки проектов на Java. Он отвечает за компиляцию, создание jar-файлов (Java-архивов), создание дистрибутива программы, генерацию документации.
🗣️ Maven — просто отличная штука, хоть поначалу и не очень понятная. Если вы никогда не использовали Maven раньше, вы многое потеряли.
🔗 Ссылочка на доку (https://maven.apache.org/guides/index.html)
👩💻
@javaquiz