@Builder 注解

@Builder 注解是 Lombok 库中的一个注解,用于自动生成复杂对象的构建器模式 (Builder Pattern)。Builder Pattern 是一种常用的设计模式,它可以使对象的创建过程更加简洁和灵活,特别是在对象有多个参数时。

以下是 @Builder 注解的一些主要用途和功能:

  1. 简化对象创建:可以使用流式接口来创建对象,而不需要编写繁琐的构造函数或 setter 方法。

  2. 可读性强:使用 Builder 模式可以提高代码的可读性,使得对象的创建过程看起来更加清晰。

  3. 可选参数:可以方便地处理可选参数,不需要为所有可能的参数组合创建多个构造函数。

  4. 不可变对象:Builder 模式通常与不可变对象(immutable objects)结合使用,从而提高代码的安全性和稳定性。

  5. 减少构造器过载:避免由于参数过多而产生的构造器过载问题。

使用示例

以下是一个使用 @Builder 注解的示例:

import lombok.Builder;
import lombok.ToString;

@Builder
@ToString
public class User {
    private String username;
    private String email;
    private int age;

    public static void main(String[] args) {
        User user = User.builder()
                        .username("john_doe")
                        .email("john@example.com")
                        .age(30)
                        .build();
        System.out.println(user);
    }
}

在这个示例中:

  • @Builder 注解会自动生成一个内部静态类 UserBuilder,其中包含了 usernameemailage 的 setter 方法。
  • 使用 User.builder() 来获得 UserBuilder 的实例,并可以链式调用 setter 方法来设置属性,最后调用 build() 方法来创建 User 实例。
  • @ToString 注解会自动生成 toString() 方法,以便于打印对象内容。

生成的代码概述

Lombok 会生成类似以下的代码:

public class User {
    private String username;
    private String email;
    private int age;

    User(String username, String email, int age) {
        this.username = username;
        this.email = email;
        this.age = age;
    }

    public static UserBuilder builder() {
        return new UserBuilder();
    }

    public static class UserBuilder {
        private String username;
        private String email;
        private int age;

        UserBuilder() {
        }

        public UserBuilder username(String username) {
            this.username = username;
            return this;
        }

        public UserBuilder email(String email) {
            this.email = email;
            return this;
        }

        public UserBuilder age(int age) {
            this.age = age;
            return this;
        }

        public User build() {
            return new User(username, email, age);
        }

        public String toString() {
            return "User.UserBuilder(username=" + this.username + ", email=" + this.email + ",
  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值