最近遇到大神写的代码中用到了lombok中的 @Builder注解,了解了一下他的作用。
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class Card {
private int id;
private String name;
private boolean sex;
}
使用:
Card card = Card.builder().id(10).name("dasd").sex(true).build();
优点
1.不需些太多的set方法来定义属性内容
2.写法更优雅
那么@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实例,所以在使用build注解时,一定要确保类中有全参构造方法,这里使用的是lombok的@NoArgsConstructor、@AllArgsConstructor注解,@Data中默认会提供一个无参构造。
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实例。
转载:https://blog.csdn.net/baidu_35085676/article/details/89193416