Lombok插件讲解

Lombok是什么?

lombok是java自动生成代码的插件。它能提高开发效率,减少自己编写繁琐的代码,让代码看起来更整洁简略,比如getter、setter、equals以及construct等方法。其也有val、var这种自动判断变量类型的变量定义方式(类似javascript中的let、const)。

Lombok使用

在开发ide中安装lombok插件,然后加上lombok的依赖包即可。如下以idea为例:

  • 插件
    这里写图片描述
    • 依赖
    <dependencies>
        <dependency>
         <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
          <optional>true</optional>
        </dependency>
    </dependencies>

Lombok特性

val

val可以用于定义局部变量,能根据变量的初始化值来推断出变量的类型,且用final进行修饰。示例如下:

import lombok.val;
import java.util.ArrayList;

public class ValExample {
    public static void main(String[] args){
        val array = new ArrayList<String>();
        array.add("val..");
        for(val obj: array){
            System.out.println(obj);
        }
    }
}

var

var和val类似,区别在于不再有final进行修饰。

@NonNull

该注解可以用于参数的空指针检查,避免出现讨厌的空指针问题。示例如下:

import lombok.NonNull;

public class NonNullExample {

    private Person person;

    public NonNullExample(@NonNull Person person){
        this.person = person;
    }

    class Person {
        private String name;
        private Integer age;
        Person(String name, Integer age){
            this.name = name;
            this.age = age;
        }
    }
}

如下是编译后的代码:

import lombok.NonNull;

public class NonNullExample {
    private NonNullExample.Person person;

    public NonNullExample(@NonNull NonNullExample.Person person) {
        if (person == null) {
            throw new NullPointerException("person is marked @NonNull but is null");
        } else {
            this.person = person;
        }
    }

    class Person {
        private String name;
        private Integer age;

        Person(String name, Integer age) {
            this.name = name;
            this.age = age;
        }
    }
}

@Cleanup

该注解可以进行资源自动管理,在作用域结束时进行资源回收。当一个局部变量被@Cleanup进行修饰时,整个变量的作用域范围会被try/finally 代码块进行包裹,在finally中调用资源回收的close方法(默认为close())。这里引用官网的例子来说明:

import lombok.Cleanup;
import java.io.*;

public class CleanupExample {
  public static void main(String[] args) throws IOException {
    @Cleanup InputStream in = new FileInputStream(args[0]);
    @Cleanup OutputStream out = new FileOutputStream(args[1]);
    byte[] b = new byte[10000];
    while (true) {
      int r = in.read(b);
      if (r == -1) break;
      out.write(b, 0, r);
    }
  }
}

编译后的代码显示如下:


import java.io.*;

public class CleanupExample {
  public static void main(String[] args) throws IOException {
    InputStream in = new FileInputStream(args[0]);
    try {
      OutputStream out = new FileOutputStream(args[1]);
      try {
        byte[] b = new byte[10000];
        while (true) {
          int r = in.read(b);
          if (r == -1) break;
          out.write(b, 0, r);
        }
      } finally {
        if (out != null) {
          out.close();
        }
      }
    } finally {
      if (in != null) {
        in.close();
      }
    }
  }
}

当然,如果某个变量类型没有close方法,而有其他的无参(只有无参的才能用户@Cleanup进行修饰,有参的不能)的资源回收的方法,可以用以下的方式进行申明变量:

@Cleanup("dispose") org.eclipse.swt.widgets.CoolBar bar = new CoolBar(parent, 0);

@Getter/@Setter

这两个注解可以用于修饰成员变量,也可以用于修饰类,会自动生成标准javabean的getter和setter方法。生成的getter和setter方法的public域,这个是可以控制的。示例如下:

import lombok.AccessLevel;
import lombok.Getter;
import lombok.Setter;

public class GeterSeterExample {

    @Getter@Setter private String name;

    @Getter(value = AccessLevel.PROTECTED)
    @Setter(value = AccessLevel.PROTECTED)
    private String size;
}

@ToString

控制重载toString方法。

@EqualsAndHashCode

生成equals和hashCode函数。

@NoArgsConstructor, @AllArgsConstructor

生成无参构造函数和全参构造函数。示例如下:

import lombok.AllArgsConstructor;
import lombok.NoArgsConstructor;

@NoArgsConstructor
@AllArgsConstructor
public class ConstructExample {
    private String name;
    private String dec;
}
public class ConstructExample {
    private String name;
    private String dec;

    public ConstructExample() {
    }

    public ConstructExample(String name, String dec) {
        this.name = name;
        this.dec = dec;
    }
}

@Data

包含如下功能,是一种简写方式。
@ToString,@EqualsAndHashCode,@Getter,@Setter,@RequiredArgsConstructor,

@Builder

生成创建对象的builder方法api,示例如下:

import lombok.Builder;

@Builder
public class BuilderExample {
    private String name;
    private String dec;
}

编译后的代码如下:

public class BuilderExample {
    private String name;
    private String dec;

    BuilderExample(String name, String dec) {
        this.name = name;
        this.dec = dec;
    }

    public static BuilderExample.BuilderExampleBuilder builder() {
        return new BuilderExample.BuilderExampleBuilder();
    }

    public static class BuilderExampleBuilder {
        private String name;
        private String dec;

        BuilderExampleBuilder() {
        }

        public BuilderExample.BuilderExampleBuilder name(String name) {
            this.name = name;
            return this;
        }

        public BuilderExample.BuilderExampleBuilder dec(String dec) {
            this.dec = dec;
            return this;
        }

        public BuilderExample build() {
            return new BuilderExample(this.name, this.dec);
        }

        public String toString() {
            return "BuilderExample.BuilderExampleBuilder(name=" + this.name + ", dec=" + this.dec + ")";
        }
    }
}

@Synchronized

安全的加锁,控制同步。引用官网的例子,如下所示:

import lombok.Synchronized;

public class SynchronizedExample {
  private final Object readLock = new Object();

  @Synchronized
  public static void hello() {
    System.out.println("world");
  }

  @Synchronized
  public int answerToLife() {
    return 42;
  }

  @Synchronized("readLock")
  public void foo() {
    System.out.println("bar");
  }
}
public class SynchronizedExample {
  private static final Object $LOCK = new Object[0];
  private final Object $lock = new Object[0];
  private final Object readLock = new Object();

  public static void hello() {
    synchronized($LOCK) {
      System.out.println("world");
    }
  }

  public int answerToLife() {
    synchronized($lock) {
      return 42;
    }
  }

  public void foo() {
    synchronized(readLock) {
      System.out.println("bar");
    }
  }
}

@Log

log注解是用于使用log日志输出的,其包含@Log、@Log4j、@Log4j2、@Slf4j等等。这里以@Slf4j为例,如下:

import lombok.extern.slf4j.Slf4j;

@Slf4j
public class LogExample {
  public static void main(String... args) {
    log.info("log info");
  }
}

@Slf4j注解会自动帮我们生成如下代码:

  private static final Logger log =LoggerFactory.getLogger(LogExample.class);

谏言

这篇文档并没有介绍全部的特性,如果想了解更多或者对以上的特性进行更深入的了解,请浏览 官方文档

猜你喜欢

转载自blog.csdn.net/qq_28851503/article/details/80961759