Lombok是一个Java库,能自动插入编辑器并构建工具,简化Java开发。通过添加注解的方式,不需要为类编写getter或eques方法,同时可以自动化日志变量。
一、Lombok的使用
1.1、安装插件
在事业Lombok的开发环境(IDEA或Eclipse)安装Lombok Plugin,
- 可以直接在插件管理中安装;
- 如果没有找到直接安装:(https://download.csdn.net/download/jkjkjkll/10741159)
1.2、引入Jar包
搜索下载lombok.jar
1.3、添加maven依赖
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.4</version>
<scope>provided</scope>
</dependency>
编译时出错,可能是没有enable注解处理器。Annotation Processors > Enable annotation processing。设置完成之后程序正常运行。
二、Lombok的常用注解
2.1 、@Data
@Data注解在类上,会为类的所有属性自动生成setter/getter、equals、canEqual、hashCode、toString方法,如为final属性,则不会为该属性生成setter方法。
@Data
public class User implements Serializable {
private static final long serialVersionUID = -8054600833969507380L;
private Integer id;
private String username;
private Integer age;
}
等价于:
public class User implements Serializable {
private static final long serialVersionUID = -8054600833969507380L;
private Integer id;
private String username;
private Integer age;
public User() {
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", age=" + age +
'}';
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
User user = (User) o;
return Objects.equals(id, user.id) &&
Objects.equals(username, user.username) &&
Objects.equals(age, user.age);
}
@Override
public int hashCode() {
return Objects.hash(id, username, age);
}
}
2.2、@Getter/@Setter
注解在类或字段,注解在类时为所有字段生成setter/getter方法,注解在字段上时只为该字段生成setter/getter方法。
2.3、@NonNull
给方法参数增加这个注解会自动在方法内对该参数进行是否为空的校验,如果为空,则抛出NPE(NullPointerException)
public class LombokTest {
@NonNull
@Setter
@Getter
private String name;
public LombokTest(@NonNull String name) {
this.name = name;
}
}
等价于:
public class LombokTest {
@NonNull
private String name;
public LombokTest(@NonNull String name) {
if (name == null) {
throw new NullPointerException("name is marked @NonNull but is null");
} else {
this.name = name;
}
}
public void setName(@NonNull String name) {
if (name == null) {
throw new NullPointerException("name is marked @NonNull but is null");
} else {
this.name = name;
}
}
@NonNull
public String getName() {
return this.name;
}
}
2.4、@Cleanup
自动管理资源,用在局部变量之前,在当前变量范围内即将执行完毕退出之前会自动清理资源,自动生成try-finally这样的代码来关闭流
public class LombokTest {
public static void main(String[] args) throws Exception {
@Cleanup
InputStream is = new FileInputStream(args[0]);
@Cleanup
OutputStream os = new FileOutputStream(args[0]);
}
}
等价于:
public class LombokTest {
public static void main(String[] args) throws Exception {
FileInputStream is = new FileInputStream(args[0]);
try {
OutputStream os = new FileOutputStream(args[0]);
if (Collections.singletonList(os).get(0) != null) {
os.close();
}
} finally {
if (Collections.singletonList(is).get(0) != null) {
is.close();
}
}
}
}
2.5、@EqualsAndHashCode
用在类上,自动生成equals方法和hashCode方法
@EqualsAndHashCode
public class LombokTest {
private String name;
private String phone;
private boolean flag;
}
等价于:
public class LombokTest {
private String name;
private String phone;
private boolean flag;
public LombokTest() {
}
public boolean equals(Object o) {
if (o == this) {
return true;
} else if (!(o instanceof LombokTest)) {
return false;
} else {
LombokTest other = (LombokTest)o;
if (!other.canEqual(this)) {
return false;
} else {
label39: {
Object this$name = this.name;
Object other$name = other.name;
if (this$name == null) {
if (other$name == null) {
break label39;
}
} else if (this$name.equals(other$name)) {
break label39;
}
return false;
}
Object this$phone = this.phone;
Object other$phone = other.phone;
if (this$phone == null) {
if (other$phone != null) {
return false;
}
} else if (!this$phone.equals(other$phone)) {
return false;
}
if (this.flag != other.flag) {
return false;
} else {
return true;
}
}
}
}
protected boolean canEqual(Object other) {
return other instanceof LombokTest;
}
public int hashCode() {
int PRIME = true;
int result = 1;
Object $name = this.name;
int result = result * 59 + ($name == null ? 43 : $name.hashCode());
Object $phone = this.phone;
result = result * 59 + ($phone == null ? 43 : $phone.hashCode());
result = result * 59 + (this.flag ? 79 : 97);
return result;
}
}
2.6、@ToString
注解在类,添加toString方法。
同Data内toString
2.7、@NoArgsConstructor, @RequiredArgsConstructor and @AllArgsConstructor
用在类上,自动生成无参构造和使用所有参数的构造函数以及把所有@NonNull属性作为参数的构造函数,如果指定staticName = “of”参数,同时还会生成一个返回类对象的静态工厂方法,比使用构造函数方便很多。
@NoArgsConstructor 生成一个无参构造器。
@ RequiredArgsConstructor 生成包含必须处理的字段的构造器。
@RequiredArgsConstructor
public class LombokTest {
private String name;
private String phone;
private transient boolean flag;
private final String finalFiled;
private static int num;
}
等价于:
public class LombokTest {
private String name;
private String phone;
private transient boolean flag;
private final String finalFiled;
private static int num;
public LombokTest(String finalFiled) {
this.finalFiled = finalFiled;
}
}
@ AllArgsConstructor 生成一个全参构造器,除static修饰的字段。@NonNull可以组合使用。
@AllArgsConstructor
public class LombokTest {
private String name;
@NonNull
private String phone;
private transient boolean flag;
private final String finalFiled;
private static int num;
}
等价于:
public class LombokTest {
private String name;
@NonNull
private String phone;
private transient boolean flag;
private final String finalFiled;
private static int num;
public LombokTest(String name, @NonNull String phone, boolean flag, String finalFiled) {
if (phone == null) {
throw new NullPointerException("phone is marked @NonNull but is null");
} else {
this.name = name;
this.phone = phone;
this.flag = flag;
this.finalFiled = finalFiled;
}
}
}
2.8、@Slf4j
注解在类,生成log变量,严格意义来说是常量。private static final Logger log = LoggerFactory.getLogger(UserController.class);
java 有很多日志的框架,这里用就只以 Log4j2 为例了
@Log4j2
public class User {
}
等价于:
public class User {
private static final Logger log = LogManager.getLogger(User.class);
}
2.9、@Synchronized
同步代码块,只能使用在类方法(static)或者对象方法(普通方法)上,synchronized关键字锁住的是this,@Synchronized注解默认使用的锁为 l o c k , 静 态 的 锁 为 lock,静态的锁为 lock,静态的锁为LOCK,也可以自己指定锁对象,
public class LombokTest {
@Synchronized
public void hello() {
}
@Synchronized
public static void helloWorld() {
}
private final Object world = new Object();
@Synchronized("world")
public void world() {
}
}
等价于:
public class LombokTest {
private final Object $lock = new Object[0];
private static final Object $LOCK = new Object[0];
private final Object world = new Object();
public LombokTest() {
}
public void hello() {
Object var1 = this.$lock;
synchronized(this.$lock) {
;
}
}
public static void helloWorld() {
Object var0 = $LOCK;
synchronized($LOCK) {
;
}
}
public void world() {
Object var1 = this.world;
synchronized(this.world) {
;
}
}
}
2.10、@Value
将类变成只读模式。会让所有类成员变量都变成 final,