1.Lombok是什么?
Lombok是一个通过注解以达到减少代码的java插件,通过注解减少set和get方法,构造方法等。
安装Lombok
首先需要安装插件,才能进行识别
File->settings->Plugins>Browse repositories->Lombok,如图
方法一 如果使用的是Maven,则可以在项目的pom.xml文件下添加依赖
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.12</version>
</dependency>
方法二 通过gradle在项目build.gradle下添加依赖
compile'javax.annotation:javax.annotation-api:1.2'
compile'org.projectlombok:lombok:1.16.6'
使用Lombok
Lombok 提供注解方式来提高代码的简洁性,常用注解有:
@Data
该注解相当于同时加上以下注解@Setter@Getter@ToString@EqualsAndHashCode
@Setter@Getter
作用于属性上,自动生成get,set方法
@NonNull
该注解快速判断是否为空,如果为空,则抛出java.lang.NullPointerException
@Synchronized
该注解自动添加到同步机制,有趣的是,生成的代码并不是直接锁方法,而是锁代码块,使用方法:
private DateFormat format =new SimpleDateFormat("MM-dd-YYYY");
@Synchronized
public String synchronizedFormat(Datedate)
{returnformat.format(date);}
生成等价代码:
private final java.lang.Object$lock= new java.lang.Object[0];
private DateFormat format = new SimpleDateFormat("MM-dd-YYYY");
public String synchronizedFormat(Date date) {
synchronized ($lock) {
return format.format(date);
}
}
@ToString
该方法大家应该非常熟悉,但需要注意的是:@ToString有多个属性可以进一步设置:
callSuper 是否输出父类的toString方法,默认为false
includeFieldNames 是否包含字段名称,默认为true
exclude 排除生成tostring的字段
@EqualsAndHashCode
1. 此注解会生成equals(Object other) 和 hashCode()方法。
2. 它默认使用非静态,非瞬态的属性
3. 可通过参数exclude排除一些属性
4. 可通过参数of指定仅使用哪些属性
5. 它默认仅使用该类中定义的属性且不调用父类的方法
6. 可通过callSuper=true解决上一点问题。让其生成的方法中调用父类的方法。
@CleanUp
注释可用于确保已分配的资源被释放,如IO的连接关闭
public void testCleanUp(){
try{
@Cleanup
ByteArrayOutputStream baos =new ByteArrayOutputStream(); baos.write(newbyte[] {'Y','e','s'});
System.out.println(baos.toString()); }
catch(IOException e) {
e.printStackTrace();
}
}
@SneakyThrows
用法比较简单,其实就是对于异常的一个整理,将checked exception 看做unchecked exception, 不处理,直接扔掉。 减少了到处写catch的不便利性。比如在线程中,catch所有异常,再比如在一些不太可能发生异常的地方,但是你又必须cache checked exception的地方使用这个annotation会显得代码比较规整,易读。或许也会显得高大上一点吧
public class SneakyThrowsExample implements Runnable {
@SneakyThrows(UnsupportedEncodingException.class)
public String utf8ToString(byte[] bytes) {
return new String(bytes, "UTF-8");
}
@SneakyThrows
public void run() {
throw new Throwable();
}
}