一言以蔽之:lombok是一种工具,提供了简单的注解来简化咱们的重复冗长Java代码。
好比一个Java Bean,注解了lombok的@Data:html
@Data public class NormalBean { private String name; }
等价于如下代码,Getter/Setter,toString,equals和hashCode方法会在编译时自动生成。java
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的官网,官网上有比较详细的文档。eclipse
lombok不只要在项目中添加jar包,也要经过插件的形式开启IDE的支持。若是你的项目是maven构建的,那么须要在pom.xml中添加如下依赖:maven
<dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.16.10</version> </dependency>
这里推荐使用bom的形式管理pom依赖。好比Spring io platform里就包含了lombok的dependencyManagement。ide
在idea下lombok的安装比较简单,在plugin里面安装lombok plugin
便可工具
将lombok.jar 复制到 eclipse.ini所在文件夹的根目录ui
编辑 eclipse.ini ,在末尾加入:this
-Xbootclasspath/a:lombok.jar -javaagent:lombok.jar
重启编码
其余的IDE添加lombok支持请看这里idea
lombok包含了不少注解,若是所有用上,的确能够精简不少的代码。但在实际的项目中,咱们经常只在定义Java Bean的时候用上lombok,而在业务代码中不多用到。由于lombok虽然能精简代码,但缺点也很是明显:
下降代码的可读性
调试困难
大部分状况下,咱们都应该将代码的可读性放在编码要考虑因素的首位,如下这几个是我以为最经常使用的几个lombok注解:
@Log和一系列相关注解(如@Log4j,@Slf4j)是我最喜欢的注解,不用写一堆的getLogger。还有@Builder也很方便,应付简单的Builder模式足以。
lombok是个很是有用的工具,可以帮助咱们精简不少臃肿冗长的代码,不过也有其局限性,推荐在定义Java Bean中使用。