创建型模式————建造者模式(2.4)

什么是建造者模式?

工厂模式聚焦于创建出一个对象,而建造者除此之外还需要为创建的对象赋值。

简单来说,建造者模式=创建对象+属性赋值。

建造者模式应用场景

建造者模式适合创建类中包含多个参数且需要定制化的情况。

简单来说,建造者模式的目的就是创造一条龙服务:不仅创建出对象,顺便给属性赋值。

以计算机为例,计算机的性能大致由CPU,显卡,内存,硬盘这几个属性构成。

市面上更多的是已经组装好的成品,而不会让用户自己去配一台电脑出来。(当然自己也是可以配的)

市场根据需求分为游戏本,办公本以及娱乐本等等。不同的种类性能是不一样的。但会在一个大致的范畴。

如果将所有的CPU,显卡,硬盘等等排列组合,电脑的种类将难以计数。所以官方推出定制本不仅缩小了选择的难度。也提供了生产的方便。

写个Demo实现:

虚线以上可以理解为服务端,一下可以理解为客户端。

那么生产一个产品的流程大致是这样的:实例化一个建造者实现类和一个指挥者装配类,调用指挥者转配类中的build方法实现建造者实现类的setter方法从而达到实例化产品的目的。

为什么需要建造者接口类和建造者实现类?

接口类控制的是产品的生产标准(实例化标准),每一个具体的产品都需要实现该接口完成产品创建。

优点:提升了扩展性。(客户端也可以通过接口的实现来创建自定义产品)

为什么需要指挥者装配类?

调用建造者实用类的setter方法即可完成产品的实例化创建,但这一部分对于每一个产品来说都是相同的。

那么在实例化产品的过程中,完全可以把这个重复且无任何变化的过程封装起来。实现代码复用。

class Computer  //产品类
{
    private String cpu;
    private String gpu;
    private String memory;
    private String hardpan;

    public String getCpu() {
        return cpu;
    }

    public void setCpu(String cpu) {
        this.cpu = cpu;
    }

    public String getGpu() {
        return gpu;
    }

    public void setGpu(String gpu) {
        this.gpu = gpu;
    }

    public String getMemory() {
        return memory;
    }

    public void setMemory(String memory) {
        this.memory = memory;
    }

    public String getHardpan() {
        return hardpan;
    }

    public void setHardpan(String hardpan) {
        this.hardpan = hardpan;
    }

    @Override
    public String toString() {
        return "Computer{" +
                "cpu='" + cpu + '\'' +
                ", gpu='" + gpu + '\'' +
                ", memory='" + memory + '\'' +
                ", hardpan='" + hardpan + '\'' +
                '}';
    }
}

interface ComputerBuilder    //建造者接口类
{
    void setCpu();
    void setGpu();
    void setMemeory();
    void setHardpan();
    Computer build();
}

class Hp_Game implements ComputerBuilder   //建造者实现类
{
    private Computer computer=new Computer();

    @Override
    public void setCpu() {
        computer.setCpu("i7 8300");
    }

    @Override
    public void setGpu() {
        computer.setGpu("rtx1080i");
    }

    @Override
    public void setMemeory() {
        computer.setMemory("32g");
    }

    @Override
    public void setHardpan() {
        computer.setHardpan("500G m2");
    }

    @Override
    public Computer build() {
        return computer;
    }
}

class Hp_Work implements ComputerBuilder
{
    private Computer computer=new Computer();

    @Override
    public void setCpu() {
        computer.setCpu("i6 7300");
    }

    @Override
    public void setGpu() {
        computer.setGpu("MX250");
    }

    @Override
    public void setMemeory() {
        computer.setMemory("4g");
    }

    @Override
    public void setHardpan() {
        computer.setHardpan("500G SATA");
    }

    @Override
    public Computer build() {
        return computer;
    }
}

class ComputerDirector   //指挥者装配类
{
    public Computer build(ComputerBuilder cb)
    {
        cb.setCpu();
        cb.setGpu();
        cb.setMemeory();
        cb.setHardpan();

        return cb.build();
    }
}

//=============================
public class APPlication
{

    public static void main(String[] args) {
        Hp_Game hp01 = new Hp_Game();
        Hp_Work hp02 = new Hp_Work();

        ComputerDirector computerDirector = new ComputerDirector();

        Computer computer_hp1=computerDirector.build(hp01);
        System.out.println(computer_hp1);

        Computer computer_hp02 =computerDirector.build(hp02);
        System.out.println(computer_hp02);

    }
}

客户端扩展一个产品实例

定义一个建造者实现类实现建造者接口类,并完成setter定制即可。

class Computer  //产品类
{
    private String cpu;
    private String gpu;
    private String memory;
    private String hardpan;

    public String getCpu() {
        return cpu;
    }

    public void setCpu(String cpu) {
        this.cpu = cpu;
    }

    public String getGpu() {
        return gpu;
    }

    public void setGpu(String gpu) {
        this.gpu = gpu;
    }

    public String getMemory() {
        return memory;
    }

    public void setMemory(String memory) {
        this.memory = memory;
    }

    public String getHardpan() {
        return hardpan;
    }

    public void setHardpan(String hardpan) {
        this.hardpan = hardpan;
    }

    @Override
    public String toString() {
        return "Computer{" +
                "cpu='" + cpu + '\'' +
                ", gpu='" + gpu + '\'' +
                ", memory='" + memory + '\'' +
                ", hardpan='" + hardpan + '\'' +
                '}';
    }
}

interface ComputerBuilder    //建造者接口类
{
    void setCpu();
    void setGpu();
    void setMemeory();
    void setHardpan();
    Computer build();
}

class Hp_Game implements ComputerBuilder   //建造者实现类
{
    private Computer computer=new Computer();

    @Override
    public void setCpu() {
        computer.setCpu("i7 8300");
    }

    @Override
    public void setGpu() {
        computer.setGpu("rtx1080i");
    }

    @Override
    public void setMemeory() {
        computer.setMemory("32g");
    }

    @Override
    public void setHardpan() {
        computer.setHardpan("500G m2");
    }

    @Override
    public Computer build() {
        return computer;
    }
}

class Hp_Work implements ComputerBuilder
{
    private Computer computer=new Computer();

    @Override
    public void setCpu() {
        computer.setCpu("i6 7300");
    }

    @Override
    public void setGpu() {
        computer.setGpu("MX250");
    }

    @Override
    public void setMemeory() {
        computer.setMemory("4g");
    }

    @Override
    public void setHardpan() {
        computer.setHardpan("500G SATA");
    }

    @Override
    public Computer build() {
        return computer;
    }
}

class ComputerDirector   //指挥者,复制给属性赋值
{
    public Computer build(ComputerBuilder cb)
    {
        cb.setCpu();
        cb.setGpu();
        cb.setMemeory();
        cb.setHardpan();

        return cb.build();
    }
}

//=============================

class Dell_Game implements ComputerBuilder
{
    private Computer computer=new Computer();

    @Override
    public void setCpu() {
        computer.setCpu("i7 9300");
    }

    @Override
    public void setGpu() {
        computer.setGpu("GTX1090");
    }

    @Override
    public void setMemeory() {
        computer.setMemory("32g");
    }

    @Override
    public void setHardpan() {
        computer.setHardpan("500G m2");
    }

    @Override
    public Computer build() {
        return computer;
    }
}

public class APPlication
{

    public static void main(String[] args) {
//        Hp_Game hp01 = new Hp_Game();
//        Hp_Work hp02 = new Hp_Work();

        ComputerDirector computerDirector = new ComputerDirector();

//        Computer computer_hp1=computerDirector.build(hp01);
//        System.out.println(computer_hp1);
//
//        Computer computer_hp02 =computerDirector.build(hp02);
//        System.out.println(computer_hp02);

        Dell_Game dell_game = new Dell_Game();
        Computer computer_Dell_game = computerDirector.build(dell_game);
        System.out.println(computer_Dell_game);

    }
}

小结

建造者模式的目的是创建对象并给属性赋值;

换个角度思考,实现接口的建造者实现类在定义的时候就是为了实现产品类的(而具体的产品类是固定的)。所以这个类本身的目的就是为了实例化另外一个类。而指挥者通过调用这个类的setter方法完成对产品类的属性赋值。

建造者模式的核心目的是创建出带有实例化属性的对象,而且有良好的扩展性。(符合开闭原则)

建造者要建造啥——开箱即用的产品。

(0)

相关推荐

  • 设计模式-创建型-建造者模式

    引言: 无论是在现实世界中还是在软件系统中,都存在一些复杂的对象,它们拥有多个组成部分,如汽车,它包括车轮.底盘.发动机.方向盘等各种部件.而对于大部分用户而言,无须知道这些部件的装配细节,也几乎不会 ...

  • 建造者模式

    如果一个对象的构建比较复杂,将一个对象的构建和对象的表示进行分离,使得同样的构建过程可以创建不同的表示,那么比较适合采用建造者模式.  builer: 为创建产品的各个部分,统一抽象接口 Abuild ...

  • 设计模式之建造者模式

    设计模式之建造者模式

  • Java设计模式-软件设计原则

    在软件开发中,为了提高软件系统的可维护性和可复用性,增加软件的可扩展性和灵活性,程序员要尽量根据6条原则来开发程序,从而提高软件开发效率.节约软件开发成本和维护成本. 1 开闭原则 对扩展开放,对修改 ...

  • 软件设计原则讲解,昭昭在目

    一.UML 图 不要觉得奇怪为什么不讲软件设计原则而说到了 UML 图,因为软件设计原则和软件设计模式中你讲到最多的便是利用类图来表示 类与类之间的关系,因此我们需要 先会看,再会理,最后再来写! 1 ...

  • 设计模式:外观模式

    外观模式(Facade) 介绍:为子系统中的一组接口提供一个统一的入口.外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用. 外部应用程序不用关心内部子系统的具体细节,这样会大大降低应用程 ...

  • 建造者模式(Bulider模式)详解

    在软件开发过程中有时需要创建一个复杂的对象,这个复杂对象通常由多个子部件按一定的步骤组合而成.例如,计算机是由 CPU.主板.内存.硬盘.显卡.机箱.显示器.键盘.鼠标等部件组装而成的,采购员不可能自 ...

  • 设计模式-创建型-抽象工厂模式

    前一章节,我们介绍了简单工厂模式以及工厂方法模式,但是这两种模式都存在一定的局限性,只能生产某一类型下的某一种产品,如果需求变更,同类型下出现了不同的产品,比如芝士披萨不仅有口味上的不同,同时存在外观 ...

  • 创建型设计模式--工厂模式、抽象工厂模式

    一.小案例分析 1.功能需求: 实现一个发送信息的功能,要便于扩展与维护. (1)发送信息的工具有很多,比如短信.微信.邮件.QQ等. (2)选择某个工具进行信息发送. 2.小菜鸡去实现: (1)定义 ...

  • 创建型模式之工厂方法

    目录 定义与特点 结构与实现 模式的结构 模式的实现 应用场景 扩展:简单工厂模式 参考文章 定义与特点 工厂方法(FactoryMethod)模式的定义:定义一个创建产品对象的工厂接口,将产品对象的 ...

  • 创建型模式之原型模式

    定义与特点 原型(Prototype)模式的定义如下:用一个已经创建的实例作为原型,通过复制该原型对象来创建一个和原型相同或相似的新对象. 在这里,原型实例指定了要创建的对象的种类.用这种方式创建对象 ...

  • 创建型模式之单例模式

    定义与特点 单例(Singleton)模式的定义:指一个类只有一个实例,且该类能自行创建这个实例的一种模式. 例如,Windows 中只能打开一个任务管理器,这样可以避免因打开多个任务管理器窗口而造成 ...

  • 创建型模式

    title: "[设计模式]创建型模式" date: 2016-03-07 18:05 tags: 设计模式 design pattern creational factory m ...

  • 设计模式-创建型-工厂模式

    工厂设计模式: 顾名思义,该模式是用来生产对象的.在面向对象的设计模式中,万物皆对象,若使用new来创建对象,就会对该对象产生强耦合,假如我们需要更换该对象,那么使用该对象的对象都需要进行修改,这显然 ...

  • 创建型模式————原型模式(2.3)

    什么是原型模式? 简单来说,通过复制的方式创建对象.(被复制的对象可以理解为模板) 原型模式的应用场景 复杂结构对象的创建. 复杂结构对象:可以理解为对象里面还有对象. [举个栗子]:点外卖的收货地址 ...