• lombok中的@Builder注解


    最近遇到大神写的代码中用到了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

     
  • 相关阅读:
    OSG中的示例程序简介(转)
    空间点到直线垂足坐标的解算方法 (转)
    OpenscenGraph中控制swapbuffer的方法(用于多机大屏幕同步显示机制)
    吏治 ? 官治 ?
    C++中使用union的几点思考(转)
    一个穷人移民美国三年的生活经历(转)
    展望99股市:谁是重组大黑马?(转)
    mysql 在一个实例运行情况下再搭建一个实例
    在CentOS下安装crontab服务
    Zabbix监控之迁移zabbix server
  • 原文地址:https://www.cnblogs.com/zhangzhiyong-/p/15011328.html
Copyright © 2020-2023  润新知