@Accessors(chain = true)和@Builder链式风格差异

使用 @Accessors(chain = true)

java 复制代码
@Data
@Accessors(chain = true)
public class PageQuery {
    private Integer pageNo = 1;
    private Integer pageSize = 20;
    private Boolean isAsc = true;
    private String sortBy;
}

// 使用方式
PageQuery query = new PageQuery()
    .setPageNo(2)
    .setPageSize(10)
    .setIsAsc(false);

// 后续还可以修改(可变对象)
query.setSortBy("id");  // ✅ 可以继续修改

使用 @Builder

@Builder 生成的 Builder 类完全忽略字段的初始值,只使用类型默认值

如果要使用设置的默认值,需要加@Builder.Default

java 复制代码
@Data
@Builder
public class PageQuery {
    private Integer pageNo = 1;      // ⚠️ 默认值不生效!需要加 @Builder.Default
    private Integer pageSize = 20;
    private Boolean isAsc = true;
    private String sortBy;
}

// 使用方式
PageQuery query = PageQuery.builder()
    .pageNo(2)        // 注意:方法名是 pageNo(),不是 setPageNo()
    .pageSize(10)
    .isAsc(false)
    .build();         // 必须调用 build() 才创建对象

// 后续修改?可以,但违背 Builder 设计初衷
query.setSortBy("id");  // ⚠️ 可以修改,但破坏了不可变性

核心区别

特性 @Accessors(chain = true) @Builder
原理 修改 setter 返回值 生成独立的 Builder 内部类
对象创建 new + 链式 setter builder() 方法
是否可变 可变对象(可后续修改) Builder 构建后通常不可变
代码侵入 修改现有 setter 新增 Builder 类
性能 无额外对象开销 多创建一个 Builder 对象
默认值支持 字段默认值直接生效 需要 @Builder.Default
相关推荐
程序大视界8 分钟前
【Python系列课程】Python正则表达式(下):环视、命名分组与日志实战
开发语言·python·正则表达式
枫叶v.39 分钟前
Agent 分层存储架构设计:从记忆方法到中间件选型
开发语言·python
AskHarries1 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
daidaidaiyu2 小时前
ThingsBoard 规则链系统源码分析和自定义定时器
java
sleven fung2 小时前
MinerU与BabelDOC与KTransformers与OpenAI API库
开发语言·python·ai·langchain
小毛驴8502 小时前
spring-boot-maven-plugin,maven-compiler-plugin 功能对比
java·python·maven
萤萤七悬2 小时前
【Python笔记】AI帮实现CLI工具-使用argparse.ArgumentParser接收命令参数
开发语言·笔记·python
iCxhust2 小时前
C# 命令行指令 查看二进制文件
开发语言·单片机·嵌入式硬件·c#·proteus·微机原理·8088单板机
csdn_aspnet2 小时前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
霸道流氓气质2 小时前
通义灵码 IDEA 插件完全使用指南
java·ide·intellij-idea