Lombok是一个Java库,它通过注解的方式来简化Java代码的编写。
1、Lombok库中常用的注解
@Getter:自动生成getter方法。
@Setter:自动生成setter方法。
@ToString:自动生成toString方法。
@EqualsAndHashCode:自动生成equals和hashCode方法。
@NoArgsConstructor:自动生成无参构造方法。
@AllArgsConstructor:自动生成全参构造方法。
@Data:自动生成getter、setter、equals、hashCode和toString方法。
@Builder:自动生成Builder模式的代码。
User user = User.builder()
.name("Tom")
.age(20)
.isVip(true)
.build();
@Slf4j:自动生成log变量,可以使用log.info()等方法输出日志。
@NonNull:标注在参数上,生成非空检查代码。
@Cleanup:自动生成try-finally代码块,用于自动关闭流等资源。
@Synchronized:自动生成同步代码块。
以上是Lombok库中常用的注解,使用这些注解可以大大简化Java代码的编写,减少了代码的冗余。
@Accessors
@Accessors(chain=true)
链式访问,该注解设置chain=true,生成setter方法返回this(也就是返回的是对象),代替了默认的返回void。
@Data
@Accessors(chain=true)
public class User {
private Integer id;
private String name;
private Integer age;
public static void main(String[] args) {
//开起chain=true后可以使用链式的set
User user=new User().setAge(31).setName("pollyduan");//返回对象
System.out.println(user);
}
}
@Accessors(fluent = true)
与chain=true类似,区别在于getter和setter不带set和get前缀。
@Data
@Accessors(fluent=true)
public class User {
private Integer id;
private String name;
private Integer age;
public static void main(String[] args) {
//fluent=true开启后默认chain=true,故这里也可以使用链式set
User user=new User().age(31).name("pollyduan");//不需要写set
System.out.println(user);
}
}
@Accessors(prefix = “f”)
set方法忽略指定的前缀。不推荐大神们这样去命名。
@Data
@Accessors(prefix = "f")
public class User {
private String fName = "Hello, World!";
public static void main(String[] args) {
User user=new User();
user.setName("pollyduan");//注意方法名
System.out.println(user);
}
}
2、@ToString注解可能引起的问题
ToString可能会引起栈溢出,当存在如下两个相互依赖的类时,并且使用了@ToString注解
@Data
public static class Customer {
private int customerId;
private String customerName;
private Order orders ;
}
@Data
public static class Order {
private int orderId;
private String orderName;
private Customer customer;
}
public static void main(String[] args) {
Customer customer = new Customer();
customer.setCustomerId(1);
customer.setCustomerName("John Doe");
Order order = new Order();
order.setOrderId(101);
order.setOrderName("Order #101");
order.setCustomer(customer);
customer.setOrders(order); // 只要任意一个引用为空,就不会内存溢出(例如:customer.setOrders(null))
System.out.println(customer); // 这将导致栈溢出错误
}
因此在使用@ToString和@Data的时候要注意这种情况。
可以使用@ToString.Exclude注解来防止无限递归
@ToString.Exclude
private Person person;
3、@Data注解可能引起的问题
Lombok中的@Data注解是一个方便的注解,可以自动生成getter、setter、equals、hashCode和toString方法,简化了Java代码的编写。但是,如果使用不当,可能会出现以下问题:
-
toString()方法可能引发无限递归:当一个类中的属性是另一个类的对象时,如果两个类都使用了@Data注解,就会出现toString()方法的无限递归,导致栈溢出。可以通过使用@ToString.Exclude注解来排除不需要在toString()方法中输出的属性。(上面已讲)
-
可能会降低代码的可读性:虽然@Data注解可以大大简化Java代码的编写,但是有时候自动生成的代码可能会比较复杂,降低了代码的可读性。可以根据实际情况选择使用@Data注解或手动编写getter、setter、equals、hashCode和toString方法。