Lombok是一个Java库,它通过注解的方式来简化Java代码的编写。
@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);
}
}
ToString可能会引起堆栈溢出,
1、当存在如下两个相互依赖的类时,并且使用了@ToString注解
@Getter
@Setter
@ToString
public class User implements Serializable {
private Person person;
}
@Getter
@Setter
@ToString
public class Person implements Serializable {
private User user;
}
2、两个对象相互依赖的情况下,并且调用了toString()方法。会无限递归调用tostring方法,且创建字符串造成内存溢出。
public static void main(String[] args) throws InterruptedException {
Person person = new Person();
User user = new User();
person.setUser(user); // 只要任意一个引用为空,就不会内存溢出(例如:person.setUser(null))
user.setPerson(person);
System.out.println(user.toString()); // 要调用tostring方法才会无限递归
}
因此在使用@ToString和@Data的时候要注意这种情况。
可以使用@ToString.Exclude注解来防止无限递归
@ToString.Exclude
private Person person;
Lombok中的@Data注解是一个方便的注解,可以自动生成getter、setter、equals、hashCode和toString方法,简化了Java代码的编写。但是,如果使用不当,可能会出现以下问题:
toString()方法可能引发无限递归:当一个类中的属性是另一个类的对象时,如果两个类都使用了@Data注解,就会出现toString()方法的无限递归,导致栈溢出。可以通过使用@ToString.Exclude注解来排除不需要在toString()方法中输出的属性。(上面已讲)
可能会降低代码的可读性:虽然@Data注解可以大大简化Java代码的编写,但是有时候自动生成的代码可能会比较复杂,降低了代码的可读性。可以根据实际情况选择使用@Data注解或手动编写getter、setter、equals、hashCode和toString方法。