Lombok中的@Builder和@Accessors

本文探讨了在Java中使用Lombok的@Builder和@Accessors注解来实现建造者模式,以简化对象实例化和赋值。@Builder用于创建构建对象的链式方法,而@Accessors通过链式getter和setter提供类似的功能。文章指出@Builder在处理复杂对象时可能产生冗余代码,而@Accessors虽然简洁但稳定性不足。建议在实际项目中根据需求选择使用,并提到了在遇到反射浅拷贝问题时的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在讨论@Builder和@Accessors之前,需要了解下为什么要使用这两者:

当我们想方便的将其进行实例化和赋值,往往会调用其构造方法来创建对象。
但一个POJO有很多参数的时候,我们想灵活的为其赋值,往往需要调用其set方法,但在并发条件下,这种做法会将非完全初始化的对象暴漏给外界的其他线程,这样做会产生数据不全的风险。
所以我们采用更加安全的建造者模式,通过链式表达式创建新的对象。

@Builder和@Accessors两者,就是通过经典的链式表达式来实现建造者模式创造对象
下面我们通过创建两个Persion对象,来比较两者差异:

两个注解的注意点
1、@Builder不支持父类对象构建,建议使用@superBuilder进行代替。
2、@Accessors需要将属性chain = true,如此可将操作默认为get&set,令其可以支持链式表达。

使用@SuperBuilder

@SuperBuilder
public class Person1 {
   
    private Long id;
    private String username;
    private String passwd;
}

编译后效果:

//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by FernFlower decompiler)
//

package com.testLombok.pojo;

public class Person1 {
   
    private Long id;
    private String username;
    private String passwd;

    protected Person1(Person1.Person1Builder<?, ?> b) {
   
        this.id = b.id;
        this.username = b.username;
        this.passwd = b.passwd;
    }

    public static Person1.Person1Builder<?, ?> builder() {
   
        return new Person1.Person1BuilderImpl();
    }

    private static final class Person1BuilderImpl extends Person1.Person1Builder<Person1, Person1.Person1BuilderImpl> {
   
        private Person1BuilderImpl() {
   
        }

        protected Person1.Person1BuilderImpl self() {
   
            return this;
        }

        public Person1 build() {
   
            return new Person1(this);
        }
    }

    public 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值