相信但凡有一点Java编程经历的人,都见过或者写过下面这种代码。这是一个简单的POJO,只有4个fields,加上构造器、equalshashtoString以及各种getter setter,前前后后加起来大约70多行代码。这还只是4个fields,如果有十个以上,那么代码行数轻轻松松过一百。如果老板或主顾们按代码行数给钱的话,Java程序员应该都发财了。

public class Mountain {
private String name;
private double latitude, longitude;
private String country;
public Mountain(String name, double latitude, double longitude, String country) {
//...巴拉巴拉
} @Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Mountain mountain = (Mountain) o;
return Double.compare(mountain.latitude, latitude) == 0 &&
Double.compare(mountain.longitude, longitude) == 0 &&
Objects.equals(name, mountain.name) && Objects.equals(country, mountain.country);
}
//各种getter setter toString hashCode...etc
}

有了代码自动生成,这种苦痛会稍微降低点,但是你的代码仍然会显得“脏乱”。Project Lombok,一个成熟的library,通过编译期插入的方式,大量减少样板代码,让你的代码显得干净、简洁、易读。相信很多人都用上了,没用的,建议赶紧上车。

安装

在Maven的pom文件中加入

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

即可安装成功。你也可以到官网下载jar包,通过IDE直接导入,但是不推荐。窃以为,连前端都少不了npm的年代,Maven和Gradle至少二选一。

另外,譬如IntelliJ Idea这种IDE,需要在plugin market里搜索lombok,下载并安装相关插件,否则IDE会报错。

使用注解简化代码

这里主要介绍一些常用注解。

剪除getter、setter样板代码

@Setter @Getter @EqualsAndHashCode @ToString(exclude = {"country"})
public class Mountain {
private String name;
private double latitude, longitude;
private String country;
}

注解的名称几乎都是自解释的。

@Setter@Getter可以生成全部非静态field的getter和setter方法,@EqualsAndHashCode可以生成标准的equals()hashCode()方法。@ToString,顾名思义,生成toString()方法,其中exclude属性用于排除不想出现在返回值中的field。

从图中也可以看出,各种getter equals等方法,已经在编译期生成了。

另外@Setter@Getter也可以注解到filed上,对于某些field,我们只想提供getter方法,直接注解field的方式更加灵活。

空值检查——@NonNull

@Setter @Getter @NonNull
public class Mountain {
private String name;
private double latitude, longitude;
private String country;
}

通过@NonNull注解,可以自动检查setter方法的入参是否非空,当传入null值时,则抛出空指针异常。它等同于以下实现,

public id setName(@NonNull final String name){
if(name == null) throw
new java.lang.NullPointerException("name");
this.name = name;
}

生成构造器

@NoArgsConstructor @AllArgsConstructor
public class Mountain {
private String name;
private double latitude, longitude;
private String country;
}

使用@NoArgsConstructor可以生成空参构造器,就像编译器平日为我们做的一样。@AllArgsConstructor可以生成包含全部非静态field的构造器。

融合多个注解——@Data

以上一个一个注解的添加上去,仍然非常的繁琐,有没有一键搞定的注解?

@Data @AllArgsConstructor
public class Mountain {
private String name;
private double latitude, longitude;
private String country;
}

@Data,相当于@ToString+ @EqualsAndHashCode+@Getter+@Setter+@RequiredArgsConstructor。配合@AllArgsConstructor几乎能覆盖日常大部分需求。

另外,@Data还有一个亲兄弟——@value,功能几乎等同于@Data+@AllArgsConstructor,不同的是,它生成的是不可变类(Immutable class)。在class关键字前会自动加上final修饰符,且不再提供各个fieldsetter参数。

生成构造器——@Build

@Builder
public class Mountain {
private String name;
private double latitude, longitude;
private String country;

@Build注解可以提供给当前对象一个构造器。不知道有咩有童鞋有过这样的经历,为了提供不同field组合的初始化构造器,结果必须写一大堆构造器重载方法。如果有10+的filed的话,仅仅构造器就有100行代码。对于这种情况,《Effetive Java》的作者建议,我们应该提供一个构造器,而不是重载一堆让人眼花缭乱的构造器。现在,我们仅仅添加一个@Build,就可以做到大神提供的最佳实践。

其调用起来也非常简单:

Mountain.builder()
.name("tai")
.country("china").latitude(22.456).build();

这样看起来是不是更加的舒服、简洁呢!

结语以及其他

另外还有@Cleanup注解,它相当于try-with-resource的另一个版本,避免手动调用各种丑陋的close()方法。在Java7之前这是很好用的,现在也可以作为你的备选项。

@Synchronized,用于标注静态方法,相当于原生的syncronize关键字。

@Log4j2配合apache的log4j2库使用,注解在class级别上

@Log4j
public class TestModel {
public void hello(){
log.info("log....");
}
}

以上都是一些常用的注解,他们可以消除我们日常大部分的POJO样板代码,使代码保持简洁、易读,更多特性和注解可以参考官方文档

Project Lombok——带给你简洁、清晰的代码的更多相关文章

  1. x-杂项-maven-repository-lombok-intro:使用PROJECT LOMBOK减少BOILERPLATE代码

    ylbtech-杂项-maven-repository-lombok-intro:使用PROJECT LOMBOK减少BOILERPLATE代码 1.返回顶部 1. REDUCING BOILERPL ...

  2. mybatis generator插件系列--lombok插件 (减少百分之九十bean代码)

    经常使用mybatis generator生成代码的你 有没有因为生成的getter/setter而烦恼呢? 有没有生成后又手动加toString/hashCode/Equals方法呢? 有没有改一个 ...

  3. 利用Lombok编写优雅的spring依赖注入代码,去掉繁人的@Autowired

    大家平时使用spring依赖注入,都是怎么写的? @Servicepublic class OrderService {@Autowiredprivate UserService userServic ...

  4. 简洁的java代码

    最近在codewars上刷题,学习到了不少简洁优雅的代码. codewars和leetcode都是刷题网站,codewars的题目难度分类比较广,适合各种不同水平的coder刷题. 刷完题后,看一下其 ...

  5. 百度地图API显示多个标注点带百度样式信息检索窗口的代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. 使用 Lombok 简化项目中无谓的Java代码

    在写使用Java时,难免会有一些模板代码要写,不然get/set,toString, hashCode, close 资源,定义构造函数等等.代码会显得很冗余,很长.Lombok项目可以是我们摆脱这些 ...

  7. 【转】通过lombok带你读透Builder构建器

    原地址:https://www.jianshu.com/p/0d8fc3df3647?from=timeline&isappinstalled=0 很久之前,我在<effective j ...

  8. HDU 1863:畅通project(带权值的并查集)

    畅通project Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  9. CPU五级流水线project(带Hazard)

    project简单介绍: 计算机组成原理课程Project--五级流水线hazard处理 思路说明: CPU架构图: CPU指令集: 代码在这里:cpu_hazard

随机推荐

  1. python_socket登陆验证_明文

    client.py import socket import struct sk=socket.socket() sk.connect(('127.0.0.1',9005)) while True: ...

  2. 224、Basic Calculator

    Implement a basic calculator to evaluate a simple expression string. The expression string may conta ...

  3. linux文件cat/tac/more/less/head/tail/find/vimdiff

    ls查看目录文件里的文件: [root@localhost test]# ls a  aa  b  c -d选项查看目录文件自身信息: [root@localhost test]# ll -d drw ...

  4. 在线调整ceph的参数

    能够动态的进行系统参数的调整是一个很重要并且有用的属性 ceph的集群提供两种方式的调整,使用tell的方式和daemon设置的方式 一.tell方式设置 调整配置使用命令: 调整mon的参数 #ce ...

  5. SMTPAuthenticationError: (535, '5.7.8 authentication failed')解决办法

    代码: 运行之后一直报错,SMTPAuthenticationError: (535, '5.7.8 authentication failed'). 查找半天是因为新浪邮箱的STMP的服务没有开启, ...

  6. js-根据日期获取本年所有周日

    /** * 方法 描述 Date() 返回当日的日期和时间. getDate() 从 Date 对象返回一个月中的某一天 (1 ~ 31). getDay() 从 Date 对象返回一周中的某一天 ( ...

  7. 去年去阿里面试,被问到ArrayList和LinkedList,我是这样回答的!

    前言 在一开始基础面的时候,很多面试官可能会问List集合一些基础知识,比如: ArrayList默认大小是多少,是如何扩容的? ArrayList和LinkedList的底层数据结构是什么? Arr ...

  8. 用大白话讲大数据HBase,老刘真的很用心(1)

    老刘今天复习HBase知识发现很多资料都没有把概念说清楚,有很多专业名词一笔带过没有解释.比如这个框架高性能.高可用,那什么是高性能高可用?怎么实现的高性能高可用?没说! 如果面试官听了你说的,会有什 ...

  9. P6631 [ZJOI2020] 序列

    可以将问题用形象的方式来表述.给定一排点,第 \(i\) 个点有它需要的覆盖次数 \(a_i\).有两种线段,一种能覆盖连续的一些点,称其为连续线段:另一种能覆盖相邻间隔为 \(1\) 的一些点,称其 ...

  10. Java基础教程——解析注解

    解析注解 Java 5开始,java.lang.reflect包下的反射API可以在运行时读取Annotation. 应用:定义一个自动执行方法的注解,解析注解.通过反射执行方法,替代配置文件. pa ...