lombok常用注解

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可能会引起堆栈溢出,
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;

3、@Data注解可能引起的问题

Lombok中的@Data注解是一个方便的注解,可以自动生成getter、setter、equals、hashCode和toString方法,简化了Java代码的编写。但是,如果使用不当,可能会出现以下问题:

  • toString()方法可能引发无限递归:当一个类中的属性是另一个类的对象时,如果两个类都使用了@Data注解,就会出现toString()方法的无限递归,导致栈溢出。可以通过使用@ToString.Exclude注解来排除不需要在toString()方法中输出的属性。(上面已讲)

  • 可能会降低代码的可读性:虽然@Data注解可以大大简化Java代码的编写,但是有时候自动生成的代码可能会比较复杂,降低了代码的可读性。可以根据实际情况选择使用@Data注解或手动编写getter、setter、equals、hashCode和toString方法。

你可能感兴趣的:(Spring,lombok,lombok常用注解,java)