简介

在之前在编写POJO时,其中的getter/setter/toString等等方法每次都要写,但是有了Lombok之后就省去了这些繁琐的操作

导入maven依赖

    <dependencies>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.10</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>

IDEA中引入Lombok支持如下:

点击File-- Settings设置界面中的plugin,安装Lombok插件:

常用的注释

@Setter :注解在类或字段,注解在类时为所有字段生成setter方法,注解在字段上时只为该字段生成setter方法。

  • @Getter :使用方法同上,区别在于生成的是getter方法。
  • @ToString :注解在类,添加toString方法。
  • @EqualsAndHashCode: 注解在类,生成hashCode和equals方法。
  • @NoArgsConstructor: 注解在类,生成无参的构造方法。
  • @RequiredArgsConstructor: 注解在类,为类中需要特殊处理的字段生成构造方法,比如final和被@NonNull注解的字段。
  • @AllArgsConstructor: 注解在类,生成包含类中所有字段的构造方法。
  • @Data: 注解在类,生成setter/getter、equals、canEqual、hashCode、-toString方法,如为final属性,则不会为该属性生成setter方法。

例子

只需要注解就能生成各种方法,给我们节省了很多时间

package com.lxs.pojo;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.util.Date;

@Data//get/set;toString等
@AllArgsConstructor//有参构造
@NoArgsConstructor//无参构造
public class Blog {
   
    private String id;
    private String title;
    private String author;
    private Date createTime;
    private int views;
}

这是写完注解之后自动生成的方法

缺点

在一些开发工具商店中没有Project Lombok支持选择。 IDE和JDK升级存在破裂的风险,并且围绕项目的目标和实施存在争议。