Java中lombok @Builder注解使用详解

简介

Lombok你们都知道,在使用POJO过程当中,它给咱们带来了不少便利,省下大量写get、set方法、构造器、equal、toString方法的时间。除此以外,经过@Builder注解,lombok还能够方便的时间建造者模式。bash

只须要定义一个静态公共的内部类便可。代码示例以下:函数

public class User {
    private Integer id;
    private String name;
    private String address;

    private User() {
    }

    private User(User origin) {
        this.id = origin.id;
        this.name = origin.name;
        this.address = origin.address;
    }

    public static class Builder {
        private User target;

        public Builder() {
            this.target = new User();
        }

        public Builder id(Integer id) {
            target.id = id;
            return this;
        }

        public Builder name(String name) {
            target.name = name;
            return this;
        }

        public Builder address(String address) {
            target.address = address;
            return this;
        }

        public User build() {
            return new User(target);
        }
    }
复制代码

若是项目中有使用lombok的话,能够直接使用@Builder注解来实现ui

改造上面的类以下:this

import lombok.Builder;
import lombok.ToString;

/**
 * @author wulongtao
 */
@ToString
@Builder
public class UserExample {
    private Integer id;
    private String name;
    private String address;
}
复制代码

如何使用:spa

UserExample userExample = UserExample.builder()
                .id(1)
                .name("aaa")
                .address("bbb")
                .build();

System.out.println(userExample);
复制代码

遇到问题

在使用@Builder过程当中,发现了一问题:子类的Builder对象没有父类的属性。这在使用上形成了必定的问题。

对于这个问题,找到了以下解法3d

  1. 对于父类,使用@AllArgsConstructor注解
  2. 对于子类,手动编写全参数构造器,内部调用父类全参数构造器,在子类全参数构造器上使用@Builder注解

经过这种方式,子类Builder对象可使用父类的全部私有属性。
可是这种解法也有两个反作用:code

  • 由于使用@AllArgsConstructor注解,父类构造函数字段的顺序由声明字段的顺序决定,若是子类构造函数传参的时候顺序不一致,字段类型还同样的话,出了错很差发现
  • 若是父类字段有增减,全部子类的构造器都要修改

虽然有这两个反作用,可是这种解法是我找到的惟一一种解决子类使用@Builder,能使用父类属性的方式。cdn

参考博客评论: Lombok’s @Builder annotation and inheritance对象

如何在使用@Builder的模式中,加入字段的默认值。由于使用了建造者模式,那么通常在类内声明字段的时候给字段默认值的方式就是无效的,须要在建造者上动手脚。

  1. 自定义静态内部类做为建造者,赋予默认值,再使用@Builder注解,这个时候lombok会补全已有的建造者类,进而使用默认值
  2. 更新的lombok有@Builder.Default声明,注解在须要默认值的字段上便可。

在评论区也有这种方式的反作用讨论,连接是: Using Lombok’s @Builder annotation with default valuesblog

相关文章
相关标签/搜索