Lombok中的@Builder注解

1.前言

  今天在看项目代码的时候, 遇到了实体类上加@Builder注解, 之前在开发的时候, 一直没有用过这个注解, 便兴致勃勃地去查了一下资料, 它也是Lombok中的注解, 我们都知道Lombok的注解是在java代码进行编译时对代码进行构建. Lombok插件的出现, 使得开发人员无需写多余的重复代码, 对于java对象的创建更是提供了Builder方法, 使得开发人员在设计实体类的时候, 对外保持private setter, 而对属性的赋值采用Builder方式, 不对外公开属性的写操作, 这种方式更加优雅, 并且符合面向对象编程的封装原则.

2.pom.xml的引入

<dependency>
	<groupId>org.projectlombok</groupId>
	<artifactId>lombok</artifactId>
	<version>1.18.12</version>
</dependency>

3.@Builder注解的应用

/**
 * @author lyh
 * @version v-1.0.0
 * @since 2021/6/3
 */
public class TestBuilder {
    public static void main(String[] args) {
        
        // 使用Builder注解来创建一个User实例
        User zs = User.builder()
                .age(15)
                .name("zs").build();
        System.out.println(zs);
        
        /**
         * 修改原对象的属性值
         * 注意: 修改实体, 要在实体的@Builder注解里面设置toBuilder = true
         * toBuilder的默认值是false,这个可以自行去查看@Builder注解类的实现
         * 里面有这样一行代码:
         * boolean toBuilder() default false;
         */
        zs = zs.toBuilder()
                .age(18).build();
        System.out.println(zs);
       
    }
}

输出:
User(name=zs, age=15)
User(name=zs, age=18)

Process finished with exit code 0
@Builder
@Getter
@ToString
public class User {

    private String name;

    private Integer age;

}

4.@Builder内部工作

        先来看一下使用@Builder注解之后, User类编译后的代码:

public class User {
    private String name;
    private Integer age;

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

    public static User.UserBuilder builder() {
        return new User.UserBuilder();
    }

    public String getName() {
        return this.name;
    }

    public Integer getAge() {
        return this.age;
    }

    public String toString() {
        return "User(name=" + this.getName() + ", age=" + this.getAge() + ")";
    }

    public static class UserBuilder {
        private String name;
        private Integer age;

        UserBuilder() {
        }

        public User.UserBuilder name(String name) {
            this.name = name;
            return this;
        }

        public User.UserBuilder age(Integer age) {
            this.age = age;
            return this;
        }

        public User build() {
            return new User(this.name, this.age);
        }

        public String toString() {
            return "User.UserBuilder(name=" + this.name + ", age=" + this.age + ")";
        }
    }
}

通过上面编译后的User类代码可以看到@Builder的内部工作结果:

  1. 创建了一个名为UserBuilder的静态内部类, 并且具有和实体类相同的属性(称为构建器).

  2. 在构建器中: 对于目标类中的所有的属性, 都会在构建器中创建对应的属性.

  3. 在构建器中: 创建一个无参的default构造方法.

  4. 在构建器中: 对于实体类中的每个参数, 都会对应创建类似于setter方法, 但是方法名是与该参数名是相同的, 并且返回值是构建器本身(便于链式调用).

  5. 在构建器中: 一个build方法, 调用此方法, 就会根据设置的值进行创建对象实例.

  6. 在构建器中: 同时也会生成一个toString() 方法.

  7. 在构建器中: 会创建一个builder()方法, 它的目的是用来创建构建器.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值