1. 简介
Lombok 是一个 Java 库,它通过注解的方式简化了 Java 语言中的一些冗长且重复的代码,使用 Lombok 可以大幅减少模板化代码,如 getter/setter、构造函数、toString
、equals
和 hashCode
方法等,接下来将详细介绍一些常用的 Lombok 注解。
2. 常用注解
2.1 @Getter / @Setter
这两个注解用于自动生成 getter 和 setter 方法。
@Getter @Setter public class User { private String name; private int age; }
2.2 @NoArgsConstructor / @RequiredArgsConstructor / @AllArgsConstructor
这三个注解分别用于生成无参构造器、带有所有 final 字段的构造器、带有所有字段的构造器。
@NoArgsConstructor @RequiredArgsConstructor @AllArgsConstructor public class User { private String name; private int age; }
2.3 @ToString
这个注解用于自动生成 toString
方法。
@ToString public class User { private String name; private int age; }
2.4 @EqualsAndHashCode
这个注解用于自动生成 equals
和 hashCode
方法。
@EqualsAndHashCode public class User { private String name; private int age; }
2.5 @Data
这个注解是 Lombok 提供的注解,用于自动生成 getter、setter、toString
、equals
、hashCode
和所有参数的构造器。
@Data public class User { private String name; private int age; }
2.6 @Slf4j / @Log4j / @Log4j2 / @Slf4j / @CommonsLog
这些注解用于自动生成日志对象。
@Slf4j public class UserService { public void addUser(User user) { log.info("Adding user: {}", user); } }
2.7 @NonNull / @Nullable
这两个注解用于标注一个变量或参数不能为 null 或可以为 null。
public void addUser(@NonNull User user) { // ... }
2.8 @Synchronized
这个注解用于自动生成同步锁。
@Synchronized public void addUser(User user) { // ... }
2.9 @Value
这个注解用于自动生成基于表达式的值。
@Value("${user.name}") private String userName;
3. FAQs
Q1: 使用 Lombok 注解后还需要手动编写 getter/setter 方法吗?
A1: 不需要,Lombok 会在编译时自动生成这些方法,如果需要自定义方法的逻辑,那么仍然可以手动编写。
Q2: Lombok 注解会影响性能吗?
A2: Lombok 注解不会影响运行时性能,因为它在编译时就会被处理,实际上,使用 Lombok 可能会提高性能,因为它可以减少模板化代码的使用。
原创文章,作者:未希,如若转载,请注明出处:https://www.kdun.com/ask/656014.html
本网站发布或转载的文章及图片均来自网络,其原创性以及文中表达的观点和判断不代表本网站。如有问题,请联系客服处理。
发表回复