理解建造者模式从@lombok开始

理解建造者模式从@lombok开始

建造者模式是设计模式的一种,将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。

在平时编码的时候,经常去使用lombok里面的一些注解,但是并没有去关注注解的实现

@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder

其实@Builder注解就是使用了建造者模式,借助lombok可以轻松去理解建造者模式,话不多,让我们一起探讨一下里面的实现

首先我们要构造一个User类

public class User {
    //用户名
    private String username;
    // 密码
    private String password;
    // 邮箱
    private String email;
    // 手机号
    private String phone;
    // 性别
    private String sex;
}

模拟@Builder的实现

第一步: 我们要在User用户的内部创建一个User的建造者(静态内部类)

该建造者包含用户的所有属性和build()

public static class UserBuilder {
        private String username;
        private String password;
        private String email;
        private String phone;
        private String sex;

        public UserBuilder() {
        }
				// 加入所有的getter方法

				// 为每一个属性提供赋值的方法, 并返回当前的对象
        public UserBuilder username(String username) {
            this.username = username;
            return this;
        }

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

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

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

				// 加入build方法, 用于返回Useruser对象
				public User build() {
            return new User(this);
	      }
    }

第二步:

在User类中加入构造方法和返回UserBuilder的builder()方法

public class User {
		
		// 构造方法
    public User(UserBuilder userBuilder) {
        this.username = userBuilder.getUsername();
        this.password = userBuilder.getPassword();
        this.email = userBuilder.getEmail();
        this.phone = userBuilder.getPhone();
        this.sex = userBuilder.getSex();
    }
		
		// 创建空的Userbuilder对象
    public static UserBuilder builder() {
        return new UserBuilder();
    }
}

第三步:测试, 可以看出使用链式的调用可以轻松的new出一个对象,并且代码十分的整洁

public static void main(String[] args) {
        User user = User.builder()
                .username("库里的球衣")
                .password("123456")
                .phone("12345678901")
                .email("123456@qq.com")
                .sex("男").build();
    }

在这里插入图片描述

如果不理解lombok注解的原理,使用起来也是很爽的,但是知道了原理,用起来会很愉悦

传统的建造者模式

建造者模式图

在这里插入图片描述

其实这里的模式图还是很好理解的:

首先创建一个空的Product产品,交付给Builder进行创建,但是Builder创建的顺序是有Director来进行确认的,Director确认好顺序后,直接使用Builder获得产品

第一步: 还是上面的User类

class User {
    //用户名
    private String username;
    // 密码
    private String password;
    // 邮箱
    private String email;
    // 手机号
    private String phone;
    // 性别
    private String sex;

    public void setUsername(String username) {
        this.username = username;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public void setPhone(String phone) {
        this.phone = phone;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    @Override
    public String toString() {
        return "User{" +
                "username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", email='" + email + '\'' +
                ", phone='" + phone + '\'' +
                ", sex='" + sex + '\'' +
                '}';
    }
}

第二步: 创建抽象的Builder类和具体的Builder类

//  抽象的User建造者
abstract class UserBuilder {
    User user;
    public abstract void username();
    public abstract void password();
    public abstract void email();
    public abstract void phone();
    public abstract void sex();

    public UserBuilder(User user) {
        this.user = user;
    }

    public User getUser() {
        return user;
    }
}

// 实现两个具体的建造者
class OneUserBuilder extends UserBuilder {

    public OneUserBuilder(User user) {
        super(user);
    }

    @Override
    public void username() {
        user.setUsername("库里的球衣");
    }

    @Override
    public void password() {
        user.setPassword("123456");
    }

    @Override
    public void email() {
        user.setEmail("123456@qq.com");
    }

    @Override
    public void phone() {
        user.setPhone("12345678901");
    }

    @Override
    public void sex() {
        user.setSex("男");
    }
}

class OtherUserBuilder extends UserBuilder {

    public OtherUserBuilder(User user) {
        super(user);
    }

    @Override
    public void username() {
        user.setUsername("克莱");
    }

    @Override
    public void password() {
        user.setPassword("123456");
    }

    @Override
    public void email() {
        user.setEmail("123456@qq.com");
    }

    @Override
    public void phone() {
        user.setPhone("12345678901");
    }

    @Override
    public void sex() {
        user.setSex("男");
    }
}

第三步: 编写一个指挥类, 用来控制建造者的执行顺序

class Director {
    private UserBuilder userBuilder;

    public Director(UserBuilder userBuilder) {
        this.userBuilder = userBuilder;
    }

    public void makeUser() {
        userBuilder.username();
        userBuilder.email();
        userBuilder.password();
        userBuilder.sex();
        userBuilder.phone();
    }
}

第四步:测试

public class TraditionalBuilderTest {

    public static void main(String[] args) {
        // 创建一个空的用户
        User user = new User();
        // 使用具体的构造者
        OneUserBuilder oneUserBuilder = new OneUserBuilder(user);
        // 可以控制建造者建造的顺序
        new Director(oneUserBuilder).makeUser();
        User user1 = oneUserBuilder.getUser();
        System.out.println(user1);
    }
}

在这里插入图片描述

总结:

  1. 要知道一点就是不使用设计模式照样可以进行软件的开发,以上的代码完全可以不使用建造者模式,可以直接使用构造函数或者setter方法进行注入,如果有注入的多种情况需要创建很多的构造方法,在使用中你要顾忌传入参数的顺序,以及setter方法的连续性等问题。
  2. 文章最开始使用@lombok里使用的链式建造者模式是传统的建造者模式的改进,二者原理是相同的,只是链式建造者模式将Director直接交给了Client, 将建造者以静态内部类的形式构建在了产品里面。

设计模式值得我们去刻意的练习

创作不易,如果对你有所帮助,请点赞+关注,后续会给你带来更多的干货!!!

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Lombok是一个Java库,它提供了一些注解,可以简化Java代码的编写。其中之一就是建造者模式(Builder pattern)。 使用Lombok的建造者模式可以方便地创建不可变对象,并且避免了手动编写大量的构造方法和setter方法。通过在类上添加`@Builder`注解,Lombok会自动生成一个内部静态类,该类包含了所有属性的setter方法,并且还提供了一个名为`build()`的方法用于构建对象。 下面是使用Lombok的建造者模式的一个简单示例: ```java import lombok.Builder; import lombok.Getter; @Builder @Getter public class Person { private final String name; private final int age; private final String address; } public class Main { public static void main(String[] args) { Person person = Person.builder() .name("John") .age(30) .address("123 Main St") .build(); System.out.println(person.getName()); // 输出:John System.out.println(person.getAge()); // 输出:30 System.out.println(person.getAddress()); // 输出:123 Main St } } ``` 在上面的示例中,我们使用`@Builder`注解在`Person`类上,然后通过调用自动生成的`builder()`方法来创建一个建造者对象。接着,我们可以使用链式调用来设置属性的值,并最后调用`build()`方法来构建不可变的`Person`对象。 需要注意的是,我们在`Person`类中的属性前添加了`final`关键字,这是为了确保对象的不可变性。此外,Lombok还会自动生成`equals()`、`hashCode()`和`toString()`等方法,以及一个私有的全参构造方法。 通过使用Lombok的建造者模式,我们可以简化代码并且提高可读性,特别是在创建拥有大量属性的对象时。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

库里的球衣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值