建造者模式(Builder)——从组装电脑开始

建造者模式(Builder)——从组装电脑开始

建造者模式概括起来就是将不同独立的组件按照一定的条件组合起来构成一个相对业务完整的对象。调用者无需知道构造的过程。

我们从组装电脑开始

让我们从买组装电脑开始吧。

首先要买一个电脑,一般都有两个选择 —— 品牌电脑和组装电脑,一般人为了省事和放心都会选择买品牌电脑(也就是整机)。在这里,为了更好的分析问题,假定我们为了性价比决定要买组装电脑。那么我们该怎么做呢。

首先我们得学习一个完整的电脑的组成部分有哪些?

经过翻查一部分资料发现,主要部件分为主板、CPU、显卡、显示屏、内存条等。这还刚开始,我们光知道这个还不行,每个硬件的品牌少说都有好几种,我们肯定希望在价格允许的情况选最好的。所以我们还得花时间找资料了解每个部件对应的品牌的口碑与使用者的实际体验情况(比如淘宝的卖家秀,以及网上一些专业的测评人的报告等)。

好了,研究完这个之后呢,总算是可以决定怎么搭配各种硬件了。但是最后又有一个问题来了,这些硬件买回来了,我们这些小白不会装啊,都不知道主机箱里每个部件对应的位置是哪里,以及怎么装上去。万一装坏了怎么办,那钱岂不是白花了。

又是一番曲折之后,总算是把整个电脑组装完毕了。就在我们举杯同庆的时候,突然发现了一个严重的问题……

“天呐,还开不了机啊,还要给电脑装系统啊”

“啊!!!那怎么办啊,都忙活一整天了。”

“还能怎么办啊?买都买了,装都装好了,只能装系统呀”

“也是,可我不会装系统啊,你会么?”

“……嗯~我也不会”

“哎,咱们还是去查资料怎么装系统吧”

上面的故事虽然在我们ITer来看,显得很搞笑和夸张。但是对于电脑小白来说,这可是绝对会发生的。因为在大学,我就是这么过来的。光怎么重装系统都花了我一天时间。

但是,别急,我们隔壁寝室的一个同学他早上说他也要买组装电脑。我们现在去看他怎么弄的吧,说实话,我既希望他也跟我们一样经过种种折磨,但是又希望他也能一帆风顺,这样就能教我们怎么装系统了啊。

什么?已经开始玩电脑了

当我们进寝室门的时候,令我们目瞪口呆的事情发生了,我发现他已经开始玩英雄联盟了,都已经三杀并成功结束游戏。

我马上就问他怎么这么快就玩上电脑了,然后我就把我一整天的遭遇发泄了出来。只见他哈哈大笑

”现在谁还自己买各种部件来装电脑啊,更何况像你们还不懂这些。“

”那不然怎么弄,品牌机同等价位的比组装机要贵好多啊“

”哈哈,你这个蠢嘛批,你可以去电脑城让老板帮你组装不就行了,你只需要为此付一些手工费就行了嘛,也不贵啊“

”……“

开始对号入座

第一则故事其实就相当于我们没有用建造者模式开发可能面临的一些问题。为了生成一个业务对象(组装电脑),我们得花很多时间精力来收集业务对象的成员信息(组成部分)。这么多对象全由我一个人(客户端)组织,这样就会强耦合,并很有可能因为一些细小需求的改变而导致整个功能异常(忘记装系统,内存条型号不对等)。从而浪费了更多的时间和精力,增加了我们的劳动成本和经济成本。

第二则故事就完全不同,我(用户/客户端)完全不需关心业务对象的构建过程,只需要找电脑城老板(构建者)要对象就行了。

首先有一个前提,就是有一个规则依据(契约)来构造一个正确的业务对象(电脑)。

所以为了以正确姿势来组装电脑,我们定义了一些必要的成员(硬件)

public interface IFullComputer {
    string Mainboard { get; }
    string CPU { get; }
    string Disk { get; }
    string Graphics { get; }
    string Display { get; }
    bool HasOperatingSystem { get; }
}

有了它才代表一个完整正确的电脑,我们先来看我们第二个故事是怎么实现结果调用的吧。

public class Client {
    // 交给电脑城老板
    private void IWantBuyComputer() {
        // 见到老板
        var boss = new ComputerCityBoss();
        // 告诉老板我想要什么配置的电脑,这里简单起就用老板推荐的
        var computerBuilder = new DefaultFullComputerBuilder();
        var computer = boss.TellMeThenReturnComputer(computerBuilder);
        Console.WriteLine("电脑组件完毕,是否预装系统:" + computer.HasOperatingSystem);
    }

}

客户端(用户)已经很简单了,就跟我们现在很多人买电脑一样,去电脑城把自己搭配的电脑配置给老板,然后就等着老板把组装好的电脑交给你。你根本不需要知道电脑组装的细节。这样从代码上就能做客户端与业务数据分离。

现在我们来看具体实现代码。

public interface IFullComputerBuilder : IFullComputer {
    IFullComputer Create();
}
public class DefaultFullComputerBuilder : AbstractFullComputerBuilder {
    protected override void SetCPU() {
    }

    protected override void SetDisk() {
    }

    protected override void SetDisplay() {
    }

    protected override void SetGraphics() {
    }

    protected override void SetMainboard() {
    }
}
// 老板与品牌商有合作
public abstract class AbstractFullComputerBuilder : IFullComputerBuilder {
    public string Mainboard { get; set; } = "默认品牌主板";
    public string CPU { get; set; } = "默认品牌CPU";
    public string Disk { get; set; } = "默认品牌内存";
    public string Graphics { get; set; } = "默认品牌显卡";
    public string Display { get; set; } = "默认品牌显示器";
    public bool HasOperatingSystem { get; set; }

    public IFullComputer Create() {
        SetMainboard();
        SetCPU();
        SetDisk();
        SetDisplay();
        SetGraphics();
        InstallOperatingSystem();
        if (!HasOperatingSystem) throw new InvalidOperationException("install faild: no operating system");
        return this;
    }

    protected abstract void SetMainboard();
    protected abstract void SetCPU();
    protected abstract void SetDisk();
    protected abstract void SetGraphics();
    protected abstract void SetDisplay();

    private void InstallOperatingSystem() {
        //if (!condition) return;
        HasOperatingSystem = true;
    }
}

老板就会根据你的要求来给你组装电脑。当然,如果你没有特殊要求,那老板就会默认用品牌合作商的,利润更多嘛。

public class ComputerCityBoss {
    public IFullComputer TellMeThenReturnComputer(IFullComputerBuilder builder) {
        return builder.Create();
    }
}

再来看.NETCore源码加深学习

我们在可以通过一些优秀的框架的源码来学习加深我们对知识点的理解。

在 .netcore 中,Builder 模式是很常见的。相信很多人都知道 .netcore 启动程序就是用 Builder 模式:

public class Program {
    public static void Main(string[] args) {
        CreateHostBuilder(args).Build().Run();
    }

    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args)
        .ConfigureWebHostDefaults(webBuilder => {
            webBuilder.UseStartup<Startup>();
        });
}

其中 IHostBuilder 就是一个构造者。我们来看默认实现者 HostBuilder 的源代码:

public IHost Build()
{
    if (_hostBuilt)
    {
        throw new InvalidOperationException("Build can only be called once.");
    }
    _hostBuilt = true;

    BuildHostConfiguration();
    CreateHostingEnvironment();
    CreateHostBuilderContext();
    BuildAppConfiguration();
    CreateServiceProvider();

    return _appServices.GetRequiredService<IHost>();
}

很明显,它所做的就跟我们之前讲的例子 —— AbstractFullComputerBuilder 做的是一样的。都了为了构成一个完整的对象,内部组织了很多的模块。而外部客户端(Program)根本不需要知道其内部的具体细节,只负责调用 Builder 即可。

原文地址:https://www.cnblogs.com/ms27946/p/builder-of-dp.html

时间: 2024-12-09 11:09:53

建造者模式(Builder)——从组装电脑开始的相关文章

建造者模式&lt;Builder&gt;

概述 将一个复杂对象的构造与它的表示分离,使同样的构建过程可以创建不同的表示,这样的设计模式被称为建造者模式 角色 建造者(Builder):为创建一个产品对象的各个部件指定抽象接口. 具体建造者(ConcreteBuilder):实现Builder的接口以构造和装配该产品的各个部件,定义并明确它所创建的表示,并 提供一个检索产品的接口 产品(Product):表示被构造的复杂对象.ConcreteBuilder创建该产品的内部表示并定义它的装配过程,包含定义组成部件的类,包括将这些部件装配成最

设计模式—建造者模式(Builder)

title: 设计模式-建造者模式 建造者模式(Builder)是一步一步创建一个复杂的对象,它允许用户只通过指定复杂对象的类型和内容就可以构建它们,用户不需要知道内部的具体构建细节.建造者模式属于对象创建型模式.我们获得一个对象的时候不是直接new这个对象出来,而是对其建造者进行属性设置,然后建造者在根据设置建造出各个对象出来.建造者模式又可以称为生成器模式. 模式结构 一个标准的建造者模式包含如下角色: Builder:抽象建造者 ConcreteBuilder:具体建造者 Director

23种设计模式--建造者模式-Builder Pattern

一.建造模式的介绍       建造者模式就是将零件组装成一个整体,用官方一点的话来讲就是将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同的表示.生活中比如说组装电脑,汽车等等这些都是建造者模式的具体体现,组装电脑反应到软件上就是一个复杂的对象,然后我们使用建造者模式的时候需要抽象一个建造类,抽象一个指挥者指挥具体实现的那个类,然后就是具体实现这个对象的类,这样就避免了每新创建一个不同的复杂对象就需要重新写一下这个类,这样就只要重写建造者就可以了,我们接下来就用组装电脑这个来说明一

5.建造者模式(Builder Pattern)

using System; using System.Collections.Generic; namespace ConsoleApplication4 { class Program { /// <summary> /// 以组装电脑为例子 /// 每台电脑的组成过程都是一致的,但是使用同样的构建过程可以创建不同的表示(即可以组装成不一样的电脑,配置不一样) /// 组装电脑的这个场景就可以应用建造者模式来设计 /// </summary> /// <param name

建造者模式(Builder)

定义 (本人在阅读完本书的中英两个版本之后发现对建造者模式十窍懂了九窍,所以直接去网上搜别人的分析了,所以本章大部分是根据网上的资料收集来的,此外,代码例子表示本书的例子不合适,也换了,所以本章和这本书关系不大.) 建造者模式是将一个复杂的对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示.建造者模式最重要的两个角色:抽象建造者(Builder)和指导者(Director),其中建造者知道怎么(How)去建造产品,而指导者知道去制造什么(What)产品,建造者模式用建房子的例子来说明

Java之建造者模式(Builder Pattern)(转)

1.概念 将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同的表示. [构建与表示分离,同构建不同表示] 与抽象工厂的区别:在建造者模式里,有个指导者,由指导者来管理建造者,用户是与指导者联系的,指导者联系建造者最后得到产品.即建造模式可以强制实行一种分步骤进行的建造过程. 建造模式是将复杂的内部创建封装在内部,对于外部调用的人来说,只需要传入建造者和建造工具,对于内部是如何建造成成品的,调用者无需关心. 举个简单的例子,如汽车,有很多部件,车轮,方向盘,发动机还有各种小零件等等,部

设计模式之建造者模式——Builder

一.概述 Builder模式,中文名为建造者模式,又名生成器模式.构建者模式等,是创建型设计模式之一.用于将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示. 1.适用性: 对象的创建比较复杂.有多种创建形式时 创建复杂对象的算法与对象内部组成和装配是相对独立的 2.UML类图 Builder:定义创建Product各个部件的抽象接口 ConcreteBuilder:继承自Builder,实现创建具体类型的Product所有部件的接口,并提供一个获取最终产品的接口. Dir

设计模式之建造者模式Builder(创建型)

1. 概述 在软件开发的过程中,当遇到一个“复杂的对象”的创建工作,该对象由一定各个部分的子对象用一定的算法构成,由于需求的变化,复杂对象的各个部分经常面临剧烈的变化,但将它们组合在一起的算法相对稳定. 例子1:买肯德基 典型的儿童餐包括一个主食,一个辅食,一杯饮料和一个玩具(例如汉堡.炸鸡.可乐和玩具车).这些在不同的儿童餐中可以是不同的,但是组合成儿童餐的过程是相同的.        客户端:顾客,想去买一套套餐(这里面包括汉堡,可乐,薯条),可以有1号和2号两种套餐供顾客选择.      

设计模式之九:建造者模式(Builder)

建造者模式: 将一个复杂对象的建造过程和它的表示分离开来,这样相同的建造过程可以创建不同的表示. Separate the construction of a complex object from its representation so that the same construction process can create different representations. 通俗一点就是如果流程是一样的,可以将这些流程抽象成一个类的一些接口,具体的创建过程可以在这个抽象类的子类中来实