对运用 lombok 仍是有很多争议的,有些公司不建议运用,有些公司又大量运用。

到底应不应该使用 lombok

咱们的想法是:可以运用,可是不要乱用。

什么是 lombok

Lombok是 一种Java™实用东西,可用来帮助开发人员消除Java的冗长代码,尤其是对于简单的Java目标(POJO) 。 它经过注释完成这一目的。 经过在开发环境中完成Lombok,开发人员可以节约构建比如hashCode() 和 equals()这样的办法以及以往用来分类各种 accessor和 mutator的大量时间。

咱们都知道运用 Java 界说目标的时分都会用到 Getter 和 Setter 办法。

尽管咱们有东西帮咱们快速生成这些办法,可是实际上仍是有点麻烦。

lombok 就可以经过一行注释来完成一切的这些办法。

lombok 可以做的不仅仅是这个,还可以经过注释 @Slf4j 来帮你完成主动界说 log。

咱们就不必写冗长的 private static final Logger logger = LoggerFactory.getLogger(ListingProcessor.class) 这句话了。

而且针对 log 的类不同,这句话也是不同的。

如何运用

假如运用 Maven 的话,直接增加下面的依靠到 pom 文件中就可以了。

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

IDEA 的插件是主动安装的,你直接启用就可以了。

IDEA 会提示你是不是在当前的项目中启用 lombok,你可以挑选启用或许不启用。

到底应不应该使用 lombok

随后便是在代码中运用注释就可以了。

如下面的代码,咱们直接简化运用注解就可以了。

到底应不应该使用 lombok

需求留意的是,运用 log 来标记日志。

到底应不应该使用 lombok

这样看起来,代码就高雅很多,也能削减不少不需求的代码。

lombok 的原理和乱用

Java 程序的解析分为:运转时解析编译时解析

一般咱们经过反射获取类、办法、注解和成员变量便是运转时解析。可是这种办法功率其实不高,要在程序运转起来才干解析。

这时分编译时解析就体现出它的价值了。

编译时解析又分为:注解处理器(Annotation Processing Tool)
JSR 269 刺进式注解处理器(Pluggable Annotation Processing API)

第一种处理器它最早是在 JDK 1.5 与注解(Annotation) 一起引进的,它是一个命令行东西,可以提供构建时基于源代码对程序结构的读取功能,可以经过运转注解处理器来生成新的中心文件,进而影响编译进程。

不过在JDK 1.8以后,第一种处理器被淘汰了,取而代之的是第二种处理器。

这样就导致了 lombok 对 JDK 的兼容性呈现了一些问题。

当你更换 JDK 版别的时分,lombok 的版别也需求一并进行更换,不然你就会呈现过错。

假如下面文章评论的过错: Java 项目编译过错 Error:java: java.lang.ExceptionInInitializer

便是由于 JDK 不兼容的问题导致的整个项目无法编译。

假如上游系统中提供的fegin client 运用了 lombok,那么下游系统有必要也运用 lombok,不然会报错,上下游系统构成了强依靠。

假如你需求对 getter 或许 setter 办法进行一些编码的话,lombok 也不是不能用,可是会有一点点的学习曲线。

归纳上面的考虑, lombok 仍是可以用的,可是不要测验一切当地都用 lombok,避免乱用。

哪怕便是为了运用 @Slf4j 来考虑的话,也是值得的。

www.ossez.com/t/lombok/14…