当前位置:网站首页>lombok @Builder注解

lombok @Builder注解

2020-12-07 15:49:57 osc_0cugk2ks

lombok @Builder注解

作用

@Builder
public class Card {
   
   
    private int id;
    private String name;
    private boolean sex;
}

使用:

Card card = Card.builder().id(10).name("dasd").sex(true).build();

优点

  • 不需些太多的set方法来定义属性内容
  • 写法更优雅

@Builder对类做了什么?

我们可以反编译生成的 Card.class

public class Card {
   
   
    private int id;
    private String name;
    private boolean sex;

    Card(int id, String name, boolean sex) {
   
   
        this.id = id;
        this.name = name;
        this.sex = sex;
    }

    public static Card.CardBuilder builder() {
   
   
        return new Card.CardBuilder();
    }

    public static class CardBuilder {
   
   
        private int id;
        private String name;
        private boolean sex;

        CardBuilder() {
   
   
        }

        public Card.CardBuilder id(int id) {
   
   
            this.id = id;
            return this;
        }

        public Card.CardBuilder name(String name) {
   
   
            this.name = name;
            return this;
        }

        public Card.CardBuilder sex(boolean sex) {
   
   
            this.sex = sex;
            return this;
        }

        public Card build() {
   
   
            return new Card(this.id, this.name, this.sex);
        }

        public String toString() {
   
   
            return "Card.CardBuilder(id=" + this.id + ", name=" + this.name + ", sex=" + this.sex + ")";
        }
    }
}

那么其实很明显了,注解在编译后使得Card类中多了一个名为Card.CardBuilder的静态内部类。这个静态类拥有和Card类相同的属性,并且他额外实现了一些方法:

1.name、sex、id等的属性方法

其实这些方法和setAttribute十分类似,只是额外返回了实例本身,这使得它可以使用类似于链式调用的写法。

2.build方法

该方法调用Card类的全参构造方法来生成Card实例。

Card类还是实现了builder方法,这个方法生成一个空的Card.CardBuilder实例。

缺点

最明显的一点,在生成Card实例之前,实际上是先创建了一个Card.CardBuilder实例,这样很明显额外占用了内存。

额外

@Builder(toBuilder = true)

这个选项允许你将一个实例化好的Card更新字段生成新的Card实例。

public Card.CardBuilder toBuilder() {
   
   
    return (new Card.CardBuilder()).id(this.id).name(this.name).sex(this.sex);
}

可以清楚的看出来,toBuilder方法是用当前实例的属性构造了一个新的Builder实例。

版权声明
本文为[osc_0cugk2ks]所创,转载请带上原文链接,感谢
https://my.oschina.net/u/4307536/blog/4778989