Java进阶教程:使用Lombok提升开发效率
Java进阶教程:使用Lombok提升开发效率
Lombok
Lombok安装
下面是通过Maven进行安装的,也可以在官网下载Jar包。
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.12</version>
</dependency>
插件安装
Lombok通过编译时根据注解插入一些相关代码,来实现其简化开发的目的。所以,在开发时,诸如Setter/Getter等都是无法进行代码提示的。IDEA推荐使用Lombok插件:

示例
@Val和@Var
前者定义常量,后者定义局部变量,其类型可以自动推测,不需要明确指出。
public static void varAndVal(var c){ //[X]不可用于形参
val a = 10; //[√]定义一个常量,其类型可自动推测
var b = 10; //[√]定义一个变量,其类型可自动推测
a++; //[X]常量无法被修改,此处报错!
b++; //[√]此处为Int类型变量,可以进行自增操作
b = "String";//[X]仍然遵循强类型规则,不可修改类型
}
@Cleanup和@SneakyThrows
使用Cleanup以确保在代码执行路径退出当前作用域之前自动清除给定资源。
@SneakyThrows
public static void cleanUp(){
@Cleanup OutputStreamWriter writer = new OutputStreamWriter(System.out);
writer.write("Hello World");
}
如果我们反编译该代码,Lombok自动为我们做了资源清理以及异常抛出
public static void cleanUp() {
try {
OutputStreamWriter writer = new OutputStreamWriter(System.out);
try {
writer.write("Hello World");
} finally {
if (Collections.singletonList(writer).get(0) != null) {
writer.close();
}
}
} catch (Throwable var5) {
throw var5;
}
}
同时我们还用了一个注解@SneakyThrows,他可以帮助我们抛出已检查的异常而开发时不需要在方法的throws子句中实际声明。
@Getter和@Setter
解放双手,不用再写访问器了!
class Hello{
@Getter
@Setter
private int a;
public static void main(String[] args) {
Hello a = new Hello();
a.setA(10); //Setter
System.out.println(a.getA()); //Getter
}
}
@NonNull
给方法参数增加这个注解会自动在方法内执行前对该参数进行是否为空的校验,如果为空,则抛出NPE(NullPointerException)
//不会打印10
public static void nonNull(@NonNull HashSet a){
System.out.println(10);
System.out.println(a.size());
} //打印10后才会抛出异常,所以方法可能错误执行一部分
public static void notNull(HashSet a){
System.out.println(10);
System.out.println(a.size());
}
加上这个注解后,实际代码如下:
public static int nonNull(@NonNull HashSet a) {
if (a == null) {
throw new NullPointerException("a");
} else {
System.out.println(10);
System.out.println(a.size());
return 10;
}
}
@ToString
为使用该注解的类生成一个toString方法,默认的toString格式为:ClassName(fieldName= fieleValue ,fieldName1=fieleValue)。
@ToString(includeFieldNames = true,exclude = {"a"})
class Hello{
@Getter
@Setter
private int a =10;
private double b =20.19;
private String c = "hello";
public static void main(String[] args) {
Hello a = new Hello();
System.out.println(a);
//RESULT:Hello(b=20.19, c=hello)
}
}
@EqualsAndHashCode
为使用该注解的类自动生成equals和hashCode方法。
@EqualsAndHashCode
class Hello{
private int a =10;
private double b =20.19;
private String c = "hello";
}
加注解很简单,但实际上Lombok帮我们重写了equals和hashCode方法,可见其equals是比较了字段的值以及是否为null而得出的。
public boolean equals(Object o) {
if (o == this) {
return true;
} else if (!(o instanceof Hello)) {
return false;
} else {
Hello other = (Hello)o;
if (!other.canEqual(this)) {
return false;
} else if (this.getA() != other.getA()) {
return false;
} else if (Double.compare(this.b, other.b) != 0) {
return false;
} else {
Object this$c = this.c;
Object other$c = other.c;
if (this$c == null) {
if (other$c == null) {
return true;
}
} else if (this$c.equals(other$c)) {
return true;
}
return false;
}
}
}
protected boolean canEqual(Object other) {
return other instanceof Hello;
}
public int hashCode() {
int PRIME = true;
int result = 1;
int result = result * 59 + this.getA();
long $b = Double.doubleToLongBits(this.b);
result = result * 59 + (int)($b >>> 32 ^ $b);
Object $c = this.c;
result = result * 59 + ($c == null ? 43 : $c.hashCode());
return result;
}
@NoArgsConstructor, @RequiredArgsConstructor, @AllArgsContructor
- @NoArgsConstructor : 生成一个无参数的构造方法
- @AllArgsContructor: 生成一个包含所有变量的构造方法
- @RequiredArgsConstructor: 会生成一个包含常量和标识了NotNull的变量的构造方法。生成的构造方法是私有的private。
对于RequiredArgsConstructor来说,它提供了一种新的构造思路,即通过静态方法,赋予其有意义的方法名,来构造对象。
private Hello(@NonNull double b, @NonNull String c) {
if (c == null) {
throw new NullPointerException("c");
} else {
this.b = b;
this.c = c;
}
}
public static Hello buildByBAndC(@NonNull double b, @NonNull String c) {
return new Hello(b, c);
}
@Data
@Data注解作用比较全,其包含注解的集合@ToString,@EqualsAndHashCode,所有字段的@Getter和所有非final字段的@Setter, @RequiredArgsConstructor。
@Builder
Builder注解可以快速实现构建者模式,即通过函数来赋值字段,以及构建最终对象。
@ToString
@Builder
class Hello{
private int a;
private double b;
private String c; public static void main(String[] args) {
Hello a = Hello.builder().a(11).b(12).c("hi").build();
System.out.println(a);
//RESULT:Hello(a=11, b=12.0, c=hi)
}
}
@Synchronized
多线程开发时,锁定this或你自己的类对象可能会产生不幸的副作用,因为不受你控制的其他代码也可以锁定这些对象,这可能会导致竞争条件和其他讨厌的线程相关错误。
@Synchronized注解类似Java中的Synchronized 关键字,但是可以隐藏同步锁,Lombok会自动去创建对象锁。
@Synchronized
public static void synchDemo1(){
System.out.println("World");
}
它实际编译的代码如下
private static final Object $LOCK = new Object[0];
public static void synchDemo1() {
synchronized($LOCK) {
System.out.println("World");
}
}
Lombok原理

参考链接
- https://juejin.im/post/5d6284815188256bf61196f3#heading-0
- https://www.projectlombok.org/
- https://juejin.im/entry/5a390ba76fb9a0451e3fed7c
- http://blog.didispace.com/java-lombok-how-to-use/
Java进阶教程:使用Lombok提升开发效率的更多相关文章
- atitit.提升开发效率---使用服务器控件生命周期 asp.net 11个阶段 java jsf 的6个阶段比较
atitit.提升开发效率---使用服务器控件生命周期 asp.net 11个阶段 java jsf 的6个阶段比较 如下列举了服务器控件生命周期所要经历的11个阶段. (1)初始化-- --在此 ...
- atitit.提升开发效率---使用server控件生命周期 asp.net 11个阶段 java jsf 的6个阶段比較
atitit.提升开发效率---使用server控件生命周期 asp.net 11个阶段 java jsf 的6个阶段比較 例如以下列举了server控件生命周期所要经历的11个阶段. (1)初始 ...
- Java进阶(三)多线程开发关键技术
原创文章,同步发自作者个人博客,转载请务必以超链接形式在文章开头处注明出处http://www.jasongj.com/java/multi_thread/. sleep和wait到底什么区别 其实这 ...
- Atitit. 提升开发效率与质量DSL ( 3) ----实现DSL的方式总结
Atitit. 提升开发效率与质量DSL ( 3) ----实现DSL的方式总结 1. 管道抽象 1 2. 层次结构抽象(json,xml etc) 1 3. 异步抽象promise 1 4. Ide ...
- atitit.提升开发效率---MDA 软件开发方式的革命(3)----自动化建表
atitit.提升开发效率---MDA 软件开发方式的革命(3)----自动化建表 1. 建模在后自动建表 1 1. 传统上,需要首先建表,在业务编码.. 1 2. 模型驱动建表---更多简化法是在建 ...
- atitit.提升开发效率---mda 软件开发方式的革命--(2)
atitit.提升开发效率---mda 软件开发方式的革命--(2) 1. 一个完整的MDA规范包含: 1 2. 一个完整的MDA应用程序包含: 1 3. MDA能够带来的最大的三个好处是什么? 2 ...
- atitit.提升开发效率---动态语言总结
atitit.提升开发效率---动态语言总结 ruby,python 都不错,就是语法不好, 应用不广泛,文档,工具都非常少,不推荐... php狠不错,就是高级特性不行.. 看来子有.net/jav ...
- atitit.提升开发效率---MDA 软件开发方式的革命(3)----自己主动化建表
atitit.提升开发效率---MDA 软件开发方式的革命(3)----自己主动化建表 1. 建模在后自己主动建表 1 1. 传统上,须要首先建表,在业务编码.. 1 2. 模型驱动建表---很多其它 ...
- atitit.提升开发效率---mda 软件开发方式的革命
atitit.提升开发效率---mda 软件开发方式的革命 1. 软件开发方式的革命开发工具的抽象层次将再次提升 1 2. 应用框架和其实现相分离 2 3. 目前的问题模型和代码不同步 2 4. MD ...
随机推荐
- Hive-2.3.6 安装
本安装依赖Haddop2.8安装 https://www.cnblogs.com/xibuhaohao/p/11772031.html 一.下载Hive与MySQL jdbc 连接驱动 apache- ...
- 引领开发工具近40年的程序员Anders Hejlsberg
有位神级程序员在近40年中一直创造引领潮流的开发工具(Turbo Pascal/Delphi/C#/TypeScript),他就是Anders Hejlsberg. 一. Anders并没有大学文凭, ...
- 简单理解php的socket编程【网摘】
php的socket编程算是比较难以理解的东西吧,不过,我们只要理解socket几个函数之间的关系,以及它们所扮演的角色,那么理解起来应该不是很难了,在笔者看来,socket编程,其实就是建立一个网络 ...
- 洛谷 P2313 [HNOI2005]汤姆的游戏 题解
P2313 [HNOI2005]汤姆的游戏 题目描述 汤姆是个好动的孩子,今天他突然对圆规和直尺来了兴趣.于是他开始在一张很大很大的白纸上画很多很多的矩形和圆.画着画着,一不小心将他的爆米花弄撒了,于 ...
- Python中多层List展平为一层
小书匠python 使用Python脚本的过程中,偶尔需要使用list多层转一层,又总是忘记怎么写搜索关键词,所以总是找了很久,现在把各种方法记录下来,方便自己也方便大家. 方法很多,现在就简单写8种 ...
- Redis企业实战的几个坑
一.前言 小伙伴们对Redis应该不陌生,Redis是系统必备的分布式缓存中间件,主要用来解决高并发下分担DB资源的负载,从而提升系统吞吐量. Redis支持多种数据类型,String(字符串).li ...
- Android Studio 和 SDK 下载、安装和环境变量配置
转Android Studio 和 SDK 下载.安装和环境变量配置https://blog.csdn.net/hahahhahahahha123456/article/details/8065135 ...
- [内网渗透]lcx端口转发
0x01 简介 lcx是一款端口转发工具,有三个功能: 第一个功能将本地端口转发到远程主机某个端口上 第二个功能将本地端口转发到本地另一个端口上 第三个功能是进行监听并进行转发使用 Lcx使用的前提是 ...
- 数据量与半监督与监督学习 Data amount and semi-supervised and supervised learning
机器学习工程师最熟悉的设置之一是访问大量数据,但需要适度的资源来注释它.处于困境的每个人最终都会经历逻辑步骤,当他们拥有有限的监督数据时会问自己该做什么,但很多未标记的数据,以及文献似乎都有一个现成的 ...
- select下拉框多选取值
本来是单选取值,现改为多选 其中<select> 标签新增multiple属性,如<select id = "sel" multiple = "mul ...