Lombok使用详解

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();

   }

}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容