跟着GPT学设计模式之建造者模式

Builder 模式,中文翻译为建造者模式或者构建者模式,也有人叫它生成器模式。允许你创建不同口味的对象同时避免构造器污染。当一个对象可能有几种口味,或者一个对象的创建涉及到很多步骤时会很有用。

现实世界例子:想象一个角色扮演游戏的角色生成器。最简单的选择是让计算机为你创建角色。但是如果你想选择一些像专业,性别,发色等角色细节时,这个角色生成就变成了一个渐进的过程。当所有选择完成时,该过程也将完成。

通过构造器、set函数创建对象没有建造者模式灵活,也就是建造者具有这三个特性:依赖关系(Dependencies)、合法校验(Preconditions)、不可变(Immutable)。

建造者模式的优点包括:

  • 分离构建和表示:通过建造者模式,将一个复杂对象的构建过程与其表示相分离,使得同样的构建过程可以创建不同的表示形式。
  • 更好的封装性和扩展性:可以将构建过程中的每个步骤封装在具体的建造者中,使得对于产品的构建过程进行更加精细的控制和管理。
  • 避免构造函数参数过多:通过使用建造者模式,可以避免通过构造函数参数传递大量的可选参数,使得构造函数的定义更加简洁明了。

建造者模式适用于需要创建复杂对象且对象的构建过程比较稳定的情况。如果对象的构建过程非常简单或者对象的表示形式只有一种,可能并不适合使用建造者模式。在实际应用中,可以根据具体需求和设计的复杂程度来选择是否使用建造者模式。

建造者模式的实现

说明

建造者模式(Builder Pattern)可以将一个复杂对象的构建过程与其表示相分离,使得同样的构建过程可以创建不同的表示。

在软件开发中,有时候需要创建一个复杂的对象,该对象可能由多个部分组成,且创建过程较为复杂。使用简单的构造函数或者静态工厂方法来创建对象可能会导致构造函数参数过多或者构造方法变得冗长复杂,不易于维护和扩展。这时,可以使用建造者模式来解决这个问题。

编程示例

有一个英雄要创建。

public final class Hero {
   
  private final Profession profession;
  private final String name;
  private final HairType hairType;
  private final HairColor hairColor;
  private final Armor armor;
  private final Weapon weapon;

  private Hero(Builder builder) {
   
    this.profession = builder.profession;
    this.name = builder.name;
    this.hairColor = builder.hairColor;
    this.hairType = builder.hairType;
    this.weapon = builder.weapon;
    this.armor = builder.armor;
  }
}

有创建者:

  public static class Builder {
   
    private final Profession profession;
    private final String name;
    private HairType hairType;
    private HairColor hairColor;
    private Armor armor;
    private Weapon weapon;

    public Builder(Profession profession, String name) {
   
      // 可以进行校验参数
      if (profession == null || name == null) {
   
        throw new IllegalArgumentException("profession and name can not be null");
      }
      this.profession = profession;
      this.name = name;
    }

    public Builder withHairType(HairType hairType) {
   
      this.hairType = hairType;
      return this;
    }

    public Builder withHairColor(HairColor hairColor) {
   
      this.hairColor = hairColor;
      return this;
    }

    public Builder withArmor(Armor armor) {
   
      this.armor = armor;
      return this;
    }

    public Builder withWeapon(Weapon weapon) {
   
      this.weapon = weapon;
      return this;
    }

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

使用:

var mage = new Hero.Builder(Profession.MAGE, "Riobard").withHairColor(HairColor.BLACK).withWeapon(Weapon.DAGGER).build();

对比构造器创建:

public Hero(Profession profession, String name, HairType hairType, HairColor hairColor, Armor armor, Weapon weapon) {
   

}

以上内容基于GPT创建和整理。

参考

相关推荐

  1. GPT设计模式建造模式

    2023-12-09 05:50:04       43 阅读
  2. GPT设计模式观察模式

    2023-12-09 05:50:04       6 阅读
  3. GPT设计模式原型模式

    2023-12-09 05:50:04       30 阅读
  4. 【前端设计模式建造模式

    2023-12-09 05:50:04       40 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-09 05:50:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-09 05:50:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-09 05:50:04       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-09 05:50:04       20 阅读

热门阅读

  1. A类中创建posix线程,线程间如何通信

    2023-12-09 05:50:04       36 阅读
  2. centos7做gitlab数据灾备项目地址指向问题

    2023-12-09 05:50:04       35 阅读
  3. C#反射加载程序集并使用

    2023-12-09 05:50:04       41 阅读
  4. 蓝桥杯:货物摆放

    2023-12-09 05:50:04       33 阅读
  5. react的sass模块化引入

    2023-12-09 05:50:04       40 阅读
  6. 更新 Node.js 和 npm 使用 nvm

    2023-12-09 05:50:04       40 阅读
  7. kubernetes的服务发现(二)

    2023-12-09 05:50:04       39 阅读
  8. 阿里云安装docker

    2023-12-09 05:50:04       39 阅读