@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
相关推荐
i220818 Faiz Ul1 小时前
个人健康系统|健康管理|基于java+Android+微信小程序的个人健康系统设计与实现(源码+数据库+文档)
android·java·vue.js·spring boot·微信小程序·毕设·个人健康系统
组合缺一1 小时前
agentscope-harness vs solon-ai-harness:Java 智能体「马具引擎」的双雄对决
java·人工智能·ai·llm·agent·solon·agentscope
zhangfeng11333 小时前
openclaw skills 小龙虾技能 通讯仿真 matlab skill Simulink Agentic Toolkit,通过kimi找到,mcp通讯
开发语言·matlab·openclaw·通讯仿真
Javatutouhouduan9 小时前
2026Java面试的正确打开方式!
java·高并发·java面试·java面试题·后端开发·java编程·java八股文
chao18984410 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
JAVA面经实录91710 小时前
Java初级最终完整版学习路线图
java·spring·eclipse·maven
赏金术士10 小时前
Kotlin 习题集 · 高级篇
android·开发语言·kotlin
Cat_Rocky11 小时前
k8s-持久化存储,粗浅学习
java·学习·kubernetes
楼兰公子11 小时前
buildroot 在编译rust时裁剪平台类型数量的方法
开发语言·后端·rust