【设计模式】建造者模式

简介: 【设计模式】建造者模式

演示汽车制造01:


1.jpg

通过UML类图看到本次参与我们演示的对象是机械手臂汽车车间两个对象,车间的汽车装备需要和对应的机械手臂绑定来完成汽车的自动化装配。


机械手臂对象

class MechanicalArm {
  name: string = "机械手";
}


汽车车间对象

class CarWorkshop {
  mechanicalArm: MechanicalArm;
  constructor(mechanicalArm: MechanicalArm) {
    this.mechanicalArm = mechanicalArm;
  }
  installCarbody() {
    console.log(`${this.mechanicalArm.name}正在安装车身。。。`);
  }
  installUnderpan() {
    console.log(`${this.mechanicalArm.name}安装底盘。。。`);
  }
  installGlass() {
    console.log(`${this.mechanicalArm.name}安装玻璃。。。`);
  }
  installTyre() {
    console.log(`${this.mechanicalArm.name}安装轮胎。。。`);
  }
}


演示装配过程

Gif动画学习自大帅老猿

5.jpg


说明

看的出我们的车间在装配车的时候需要很明确的由调用方将每一步流程全部执行一次,我们要是创建更多更多的汽车的话很有可能会遗漏部分装配过程,我们的🚗🚗将会变的残缺的,那么我们下一步进行简单的封装将我们的构建变得简单一点。


演示汽车制造02:


2.jpg我们引入一个Bmw建造者对象,将汽车的装配进行封装,使得我们在调用的时候变得简单,多次创建变得更加稳定。


Bmw建造者对象

class BmwBuilder {
  cws: CarWorkshop;
  constructor(cws: CarWorkshop) {
    this.cws = cws;
  }
  build(type: string) {
    console.log(`${type}汽车装配中:`);
    this.cws.installCarbody();
    this.cws.installGlass();
    this.cws.installTyre();
    this.cws.installUnderpan();
  }
}


演示装配过程

6.jpg


说明

封装的Bmw建造者在我们每个系列的🚗型装配中没有了应为短缺流程造成的问题,但是如果我们要有一个Audi🚗要装配呢?还是会有问题,我们接着往下看。


建造者模式:


Builder,将一个复杂对象的构建和表示进行分离,是的同样的构建过程可创建不同的表示。通过建造者模式我们将建造的过程和细节进行封装,使用户的使用变得简单。

我们现在加入CarDirector对象统一装配,引入CarBuilder抽象对象将我们原有的BmwBuilder对象进行重构,并新加入AudiBuilder对象,4.jpg


CarDirector

class CarDirector {
  builder: CarBuilder;
  constructor(builder: CarBuilder) {
    this.builder = builder;
  }
  create() {
    console.log("准备开始装配:");
    this.builder.buildCarbody();
    this.builder.buildGlass();
    this.builder.buildTyre();
    this.builder.buildUnderpan();
  }
}


CarBuilder

abstract class CarBuilder {
  cws!: CarWorkshop;
  abstract buildCarbody(): void;
  abstract buildGlass(): void;
  abstract buildTyre(): void;
  abstract buildUnderpan(): void;
}


BmwBuilder/AudiBuilder

class BmwBuilder extends CarBuilder {
  constructor(cws: CarWorkshop) {
    super();
    this.cws = cws;
  }
  buildCarbody() {
    this.cws.installCarbody();
  }
  buildGlass() {
    this.cws.installGlass();
  }
  buildTyre() {
    this.cws.installTyre();
  }
  buildUnderpan() {
    this.cws.installUnderpan();
  }
}


演示装配过程

直接看代码吧,动画实在不熟练呐。。。

// 购买机械手臂
const ma = new MechanicalArm();
// 打开01号车间,将机械手臂安装到汽车车间
const cws = new CarWorkshop(ma);
// Bmw流水线
const bmwCws = new BmwBuilder(cws);
// Audi流水线
const audiCws = new AudiBuilder(cws);
// 统一装配
new CarDirector(bmwCws).create();
new CarDirector(audiCws).create();


说明

同样的代码行数我们已经做了两次汽车装配了,我们现在可以随时扩展Builder来完整不同汽车的装配,还非常的稳定,高效。


总结:


当我们创建复杂对象的算法应独立于该对象的组成部分以及他们的装配方式时使用建造者模式。



相关文章
|
7月前
|
设计模式 Java
【设计模式系列笔记】建造者模式
建造者模式是一种创建型设计模式,用于将复杂对象的构建与其表示分离,使构建过程可定制。关键元素包括产品类(定义要构建的对象)、建造者接口(定义构建方法)、具体建造者类(实现构建过程)和指导者类(负责构建过程)。通过建造者模式,客户端可以灵活地创建具有不同表示的复杂对象,提高代码的可读性和可维护性,尤其适用于构建过程复杂且包含多个可选部分的情况。
139 1
|
7月前
|
设计模式 安全 Java
构建未来应用:Java设计模式 - 建造者模式(Builder)在现代编程中的应用
【4月更文挑战第7天】建造者模式是提升代码质量的关键,尤其在复杂环境中。它分步骤构建对象,将构建与表示分离,适用于UI构建、数据模型组装、配置文件解析和网络请求构造等场景。最佳实践包括明确构建步骤、提供默认值、支持链式调用和确保线程安全。然而,过多步骤、不一致状态和性能问题是使用时需注意的问题。掌握建造者模式对于现代编程至关重要。
90 3
|
3月前
|
设计模式 算法
设计模式--建造者模式 builder
这篇文章通过一个电脑购买的例子,详细解释了建造者模式的四个角色(产品类、抽象构建者、实体构建类和指导者类),并提供了相应的代码实现,阐述了建造者模式在设计复杂对象时的应用和优势。
设计模式--建造者模式 builder
|
1月前
|
设计模式 JavaScript Java
Java设计模式:建造者模式详解
建造者模式是一种创建型设计模式,通过将复杂对象的构建过程与表示分离,使得相同的构建过程可以创建不同的表示。本文详细介绍了建造者模式的原理、背景、应用场景及实际Demo,帮助读者更好地理解和应用这一模式。
|
3月前
|
设计模式 算法 Java
Java设计模式-建造者模式(6)
Java设计模式-建造者模式(6)
|
4月前
|
设计模式 XML 存储
【四】设计模式~~~创建型模式~~~建造者模式(Java)
文章详细介绍了建造者模式(Builder Pattern),这是一种创建型设计模式,用于将复杂对象的构建与其表示分离,允许分步骤创建一个复杂的对象而无需指定其内部的具体构造细节。通过定义抽象建造者、具体建造者、指挥者和产品角色,建造者模式允许通过相同的构建过程创建不同的产品表示,提高了系统的灵活性和扩展性。
|
6月前
|
设计模式 算法
建造者模式-大话设计模式
建造者模式-大话设计模式
|
7月前
|
设计模式 uml
大话设计模式(3)——造物者一般的建造者模式
大话设计模式(3)——造物者一般的建造者模式
46 1
大话设计模式(3)——造物者一般的建造者模式
|
5月前
|
设计模式 JavaScript
js设计模式【详解】—— 建造者模式
js设计模式【详解】—— 建造者模式
59 0
|
6月前
|
设计模式
设计模式-05建造者模式(Builder Pattern)
设计模式-05建造者模式(Builder Pattern)
下一篇
DataWorks