digital-garden/knowledge/dev/java/Не используйте @Data.md
2024-06-13 21:01:37 +03:00

3.2 KiB
Raw Blame History

aliases tags date zero-link parents linked article
зрелость/🌱
2023-11-20
https://struchkov.dev/blog/ru/do-not-use-lombok-data/

Многие разработчики в принципе против использования Lombok. В общем, это холиварная тема. Но вы используете Lombok в проекте, то не используйте хотя бы спорные и откровенно вредные аннотации.

Одна из таких это @Data. Во-первых, мало кто помнит, что она под собой скрывает.

  • @ToString. Не помню, когда последний раз переопределял toString(). А если объект содержит чувствительную информацию?
  • @EqualsAndHashCode. Это самая вредная аннотация в @Data. ==Потому что она генерирует equals() и hashCode() по всем полям.== Обычно вы не хотите, чтобы генерация осуществлялась по всем полям. Например, для сущности достаточно идентификатора.
  • @Getter / @Setter. Здесь ничего плохого.
  • @RequiredArgsConstructor. Тоже окей.

Основная проблема в @EqualsAndHashCode. Можно, конечно, использовать @EqualsAndHashCode.Exclude. Эта аннотация запрещает использовать поле при генерации, но вы хотите расставлять это над почти всеми полями в сущности? Потому что @EqualsAndHashCode.Include просто не сработает, нельзя объявить только нужные поля, нужно будет именно исключать все ненужные.

Также избегайте всех аннотаций из пакета experemental. Все аннотации из этого пакета могут работать не стабильно, и при этом могут быть удалены из следующих версий. Исключением из этого пакета является @FieldNameConstants, за пару лет с ней не было никаких проблем, а все имеющиеся альтернативы не очень.

С Lombok код выглядит чище, но, как и в случае с любым другим магическим инструментом, важно понимать, как именно он работает и когда его использовать. В противном случае производительность приложения может снизиться, либо оно вовсе может перестать работать корректно.

Дополнительные материалы