微服务公用实体类andLombok

假如服务A用到一个EmpBean.java,咱们创建一个。java

而后B服务也用到一个EmpBean.java,咱们偷个懒,复制过来不要紧=。=框架

可是C,D,E服务都要用到这个实体类。。。咱们就能够把他封装到一个Jar包里编辑器

而后让须要的微服务引入个这Jar,导包调用ide

 

而后可让这个工程加入Lombok(专门省事实体类的)依赖微服务

<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.4</version>
    <scope>provided</scope>
</dependency>

说道Lombok,可能会不为人知。可是在实际的开发中,它起到了很大的做用,话很少说,直入正题:工具

1、Lombok是什么spa

    如今看一下Lombok官方对其进行的解释:Lombok官网:https://projectlombok.org.net

 

第一句话,Lombok项目是一种自动接通你的编辑器和构建工具的一个Java库。接着,不用再一次写额外的getter或者equals方法。翻译到这里其实就能够,后面是对Lombok早期应用的介绍。经过这两句话不难理解lombok其实就是帮助咱们编写getter或者equals方法的一个“工具”。其实他的魅力并不在于帮助咱们简单的编写对应的getter或者更多的方法,还有一点在于,当咱们的字段发生改变时,lombok也会对相应的getter方法进行改变。插件

2、为何要在本身的项目中使用Lombok翻译

   要回答这个问题,仅仅知道什么是Lombok是不够的。在讲解原理以前我想再提一点 ,这也是为何要使用Lombok的关键所在:根据Lombok的使用规则,若是想要使用Lombok就须要删除在项目中(JavaBean)存在的已经生成的getter方法setter方法以及equals和hash方法,固然Lombok也提供了对打印日志的处理。这样在使用Lombok之后就会大大减小项目中的代码量,同时因为Lombok有自动修改的功能,这也提供了项目中代码的执行效率。

   综上所述,使用Lombok的两点主要缘由就是:

        (1)、简化冗余的JavaBean代码;

        (2)、大大提升JavaBean中方法的执行效率;

Lombok实现原理

    Lombok实现了JSR 269 API规范,javac在Java6开始支持这一规范,只要程序实现了该API,就能在javac运行的时候获得调用,那么Lombok在编译时使用的就是javac,具体流程以下:

首先是项目的源代码文件,在通过编译处理之后,lombok会使用本身的抽象语法树去进行注解的匹配,若是在项目中的某一个类中使用了lombok中的注解,那么注解编译器就会自动去匹配项目中的注解对应到在lombok语法树中的注解文件,并通过自动编译匹配来生成对应类中的getter或者setter方法,达到简化代码的目的。执行顺序就如上图的叠放顺序。

5、Lombok注解详解

   Lombok主要经常使用的注解有:@Data,@getter,@setter,@NoArgsConstructor,@AllArgsConstructor,@ToString,@EqualsAndHashCode,@Slf4j,@Log4j。咱们一个一个来看:

@Data注解:在JavaBean或类JavaBean中使用,这个注解包含范围最广,它包含getter、setter、NoArgsConstructor注解,即当使用当前注解时,会自动生成包含的全部方法;

@getter注解:在JavaBean或类JavaBean中使用,使用此注解会生成对应的getter方法;

@setter注解:在JavaBean或类JavaBean中使用,使用此注解会生成对应的setter方法;

@NoArgsConstructor注解:在JavaBean或类JavaBean中使用,使用此注解会生成对应的无参构造方法;

@AllArgsConstructor注解:在JavaBean或类JavaBean中使用,使用此注解会生成对应的有参构造方法;

@ToString注解:在JavaBean或类JavaBean中使用,使用此注解会自动重写对应的toStirng方法;

@EqualsAndHashCode注解:在JavaBean或类JavaBean中使用,使用此注解会自动重写对应的equals方法和hashCode方法;

@Slf4j:在须要打印日志的类中使用,当项目中使用了slf4j打印日志框架时使用该注解,会简化日志的打印流程,只需调用info方法便可;

@Log4j:在须要打印日志的类中使用,当项目中使用了log4j打印日志框架时使用该注解,会简化日志的打印流程,只需调用info方法便可;

在使用以上注解须要处理参数时,处理方法以下(以@ToString注解为例,其余注解同@ToString注解):

@ToString(exclude="column")

意义:排除column列所对应的元素,即在生成toString方法时不包含column参数;

@ToString(exclude={"column1","column2"})

意义:排除多个column列所对应的元素,其中间用英文状态下的逗号进行分割,即在生成toString方法时不包含多个column参数;

@ToString(of="column")

意义:只生成包含column列所对应的元素的参数的toString方法,即在生成toString方法时只包含column参数;;

@ToString(of={"column1","column2"})

意义:只生成包含多个column列所对应的元素的参数的toString方法,其中间用英文状态下的逗号进行分割,即在生成toString方法时只包含多个column参数;

6、使用Lombok可能须要注意的地方

    (1)、当你的IDE是Idea时,要注意你的Idea是支持Lombok的,若是不支持请更换2017版本尝试。

   (2)、在使用Lombok时,你的编辑器可能会报错,这时请在你的IDE中安装Lombok插件(若是使用的Idea则直接搜索Lombok插件,选择星级最高的,直接安装就是,其余Ide类同)。

   (3)、参数的处理每每都是根据项目需求来进行,请妥善处理参数。

   (4)、若是你没法访问Lombok官网,你能够从这篇博文中将Maven坐标照着本身打进去,或者你也能够访问Maven的中央仓库搜索Lombok,将Maven坐标复制进去便可。

https://blog.csdn.net/u011719271/article/details/53842420