使用Lombok来精简你的项目代码

什么是Lombok

一言以蔽之:lombok是一种工具,提供了简单的注解来简化我们的重复冗长Java代码。
比如一个Java Bean,注解了lombok的@Data:

@Data
public class NormalBean {
    private String name;
}

等价于以下代码,Getter/Setter,toString,equals和hashCode方法会在编译时自动生成。

public class NormalBean {
    private String name;
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
 
        NormalBean that = (NormalBean) o;
 
        return name != null ? name.equals(that.name) : that.name == null;
 
    }
 
    @Override
    public int hashCode() {
        return name != null ? name.hashCode() : 0;
    }
 
    @Override
    public String toString() {
        return "NormalBean{" +
                "name='" + name + '\'' +
                '}';
    }
}

安装

lombok不仅要在项目中添加jar包,也要通过插件的形式开启IDE的支持。如果你的项目是maven构建的,那么需要在pom.xml中添加以下依赖:

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
</dependency>

idea

在idea下lombok的安装比较简单,在plugin里面安装lombok plugin即可

eclipse

  • 点击这里,下载lombok.jar包

  • 将lombok.jar 复制到 eclipse.ini所在文件夹的根目录

  • 使用Lombok来精简你的项目代码

  • 编辑 eclipse.ini ,在末尾加入:

        -Xbootclasspath/a:lombok.jar
        -javaagent:lombok.jar
    

     

  • 重启

    用途

    lombok包含了很多注解,如果全部用上,的确可以精简很多的代码。但在实际的项目中,我们常常只在定义Java Bean的时候用上lombok,而在业务代码中很少用到。因为lombok虽然能精简代码,但缺点也非常明显:

  • 降低代码的可读性

  • 调试困难

  • 大部分情况下,我们都应该将代码的可读性放在编码要考虑因素的首位,以下这几个是我觉得最常用的几个lombok注解:

  • @Data

  • @Setter/Getter

  • @Log

  • @Log和一系列相关注解(如@Log4j,@Slf4j)是我最喜欢的注解,不用写一堆的getLogger。还有@Builder也很方便,应付简单的Builder模式足以。

    总结

    lombok是个非常有用的工具,能够帮助我们精简很多臃肿冗长的代码,不过也有其局限性,推荐在定义Java Bean中使用。

  • @NoArgsConstructor, @RequiredArgsConstructor和 @AllArgsConstructor

  • @Builder