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可能会引起栈溢出,当存在如下两个相互依赖的类时,并且使用了@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方法。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值