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 可能会提高性能,因为它可以减少模板化代码的使用。
本文名称:lombok常用注解
网页地址:http://www.jxjierui.cn/article/dhepihs.html


咨询
建站咨询
