2022年9月8号Java23设计模式学习(课时四)建造者模式

简介: 2022年9月8号Java23设计模式学习(课时四)建造者模式

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


实用范围

1 当创建复杂对象的算法应该独立于该对象的组成部分以及它们的装配方式时。 [1]

2 当构造过程必须允许被构造的对象有不同表示时。


角色

在这样的设计模式中,有以下几个角色:


1 builder:为创建一个产品对象的各个部件指定抽象接口。


2 ConcreteBuilder:实现Builder的接口以构造和装配该产品的各个部件,定义并明确它所创建的表示,并提供一个检索产品的接口。


3 Director:构造一个使用Builder接口的对象。


4 Product:表示被构造的复杂对象。ConcreteBuilder创建该产品的内部表示并定义它的装配过程,包含定义组成部件的类,包括将这些部件装配成最终产品的接口。

案例一:我要建房子请思考房子该如何建立呢!

package coms.Design.Mode.Builder;
/**
 * 抽象的建造者模式
 * 建造者的模式
 */
public abstract class Builder {
    abstract  void  builderA(); //选地方
    abstract  void  builderB(); //打地基
    abstract  void  builderC(); //构建图纸
    abstract  void  builderD(); //搭建房屋框架
    abstract  void  builderE(); //开始建造
    abstract  void  builderF(); //装修
    abstract Product getProduct();  //得到产品
}
package coms.Design.Mode.Builder;
public class Worker extends  Builder {
    private  Product product;
    public Worker() {
        this.product = new Product();
    }
    @Override
    void builderA() {
        product.setBuStringA("选地方");
        System.out.println("地方完毕");
    }
    @Override
    void builderB() {
        product.setBuStringB("打地基");
        System.out.println("地基打建造完毕");
    }
    @Override
    void builderC() {
        product.setBuStringC("构建图纸");
        System.out.println("图纸构建完毕");
    }
    @Override
    void builderD() {
        product.setBuStringD("搭建房屋框架");
        System.out.println("搭建房屋框架完毕");
    }
    @Override
    void builderE() {
        product.setBuStringE("开始建造");
        System.out.println("开始建造建造目标三层");
    }
    @Override
    void builderF() {
        product.setBuStringF("装修");
        System.out.println("装修资金60w");
    }
    @Override
    Product getProduct() {
        return product;
    }
}
package coms.Design.Mode.Builder;
/**
 * 产品 房子
 */
public class Product {
    private  String buStringA;
    private  String buStringB;
    private  String buStringC;
    private  String buStringD;
    private  String buStringE;
    private  String buStringF;
    public String getBuStringA() {
        return buStringA;
    }
    public void setBuStringA(String buStringA) {
        this.buStringA = buStringA;
    }
    public String getBuStringB() {
        return buStringB;
    }
    public void setBuStringB(String buStringB) {
        this.buStringB = buStringB;
    }
    public String getBuStringC() {
        return buStringC;
    }
    public void setBuStringC(String buStringC) {
        this.buStringC = buStringC;
    }
    public String getBuStringD() {
        return buStringD;
    }
    public void setBuStringD(String buStringD) {
        this.buStringD = buStringD;
    }
    public String getBuStringE() {
        return buStringE;
    }
    public void setBuStringE(String buStringE) {
        this.buStringE = buStringE;
    }
    public String getBuStringF() {
        return buStringF;
    }
    public void setBuStringF(String buStringF) {
        this.buStringF = buStringF;
    }
    @Override
    public String toString() {
        return "Product{" +
                "buStringA='" + buStringA + '\'' +
                ", buStringB='" + buStringB + '\'' +
                ", buStringC='" + buStringC + '\'' +
                ", buStringD='" + buStringD + '\'' +
                ", buStringE='" + buStringE + '\'' +
                ", buStringF='" + buStringF + '\'' +
                '}';
    }
}
package coms.Design.Mode.Builder;
/**
 * 指挥者 构建工程
 * 按照步骤建立房子
 */
public class Director {
    /**
     * 步骤是指挥者来改变
     * @param builder
     * @return
     */
    public  Product build(Builder builder){
        builder.builderA();
        builder.builderB();
        builder.builderC();
        builder.builderD();
        builder.builderE();
        builder.builderF();
       return  builder.getProduct();
    }
}
package coms.Design.Mode.Builder;
public class Test {
    public static void main(String[] args) {
        //指挥者
        Director director =new Director();
        //指挥具体的工人
        Product  build=director.build(new Worker());
        System.out.println(build.toString());
    }
}


案例二:我是老板要定制套餐该如何做呢!

package coms.Design.Mode.Builder2;
//建造者
public  abstract  class Builder {
    /**
     * 抽象四个产品
     * @return
     */
    abstract Builder builderA(String msg);
    abstract Builder builderB(String msg);
    abstract Builder builderC(String msg);
    abstract Builder builderD(String msg);
    abstract  Product getProduct();
}
package coms.Design.Mode.Builder2;
/**
 * 建造者
 */
public class Worker extends Builder {
    private  Product product;
    public Worker() {
         product = new Product();
    }
    @Override
    Builder builderA(String msg) {
        product.setBuidA(msg);
        return this;
    }
    @Override
    Builder builderB(String msg) {
        product.setBuidB(msg);
        return this;
    }
    @Override
    Builder builderC(String msg) {
        product.setBuidC(msg);
        return this;
    }
    @Override
    Builder builderD(String msg) {
        product.setBuidD(msg);
        return this;
    }
    @Override
    Product getProduct() {
        return product;
    }
}

package coms.Design.Mode.Builder2;
/**
 * 产品套餐
 */
public class Product {
    private  String BuidA="汉堡";
    private  String BuidB="可乐";
    private  String BuidC="食物";
    private  String BuidD="小鸡";
    public String getBuidA() {
        return BuidA;
    }
    public void setBuidA(String buidA) {
        BuidA = buidA;
    }
    public String getBuidB() {
        return BuidB;
    }
    public void setBuidB(String buidB) {
        BuidB = buidB;
    }
    public String getBuidC() {
        return BuidC;
    }
    public void setBuidC(String buidC) {
        BuidC = buidC;
    }
    public String getBuidD() {
        return BuidD;
    }
    public void setBuidD(String buidD) {
        BuidD = buidD;
    }
    @Override
    public String toString() {
        return "Product{" +
                "BuidA='" + BuidA + '\'' +
                ", BuidB='" + BuidB + '\'' +
                ", BuidC='" + BuidC + '\'' +
                ", BuidD='" + BuidD + '\'' +
                '}';
    }
}

package coms.Design.Mode.Builder2;
import com.sun.glass.ui.Window;
public class Test {
    public static void main(String[] args) {
        //服务员
        Worker worker=new Worker();
        Product product=worker.getProduct();
        //链式编程  步骤交给了客选择
        Product product1=worker.builderA("全家桶").getProduct();
        System.out.println(product.toString());
    }
}



动手实战以下

相关文章
|
8月前
|
设计模式 网络协议 数据可视化
Java 设计模式之状态模式:让对象的行为随状态优雅变化
状态模式通过封装对象的状态,使行为随状态变化而改变。以订单为例,将待支付、已支付等状态独立成类,消除冗长条件判断,提升代码可维护性与扩展性,适用于状态多、转换复杂的场景。
1017 157
|
8月前
|
设计模式 Java Spring
Java 设计模式之责任链模式:优雅处理请求的艺术
责任链模式通过构建处理者链,使请求沿链传递直至被处理,实现发送者与接收者的解耦。适用于审批流程、日志处理等多级处理场景,提升系统灵活性与可扩展性。
848 2
|
10月前
|
设计模式 缓存 Java
Java设计模式(二):观察者模式与装饰器模式
本文深入讲解观察者模式与装饰器模式的核心概念及实现方式,涵盖从基础理论到实战应用的全面内容。观察者模式实现对象间松耦合通信,适用于事件通知机制;装饰器模式通过组合方式动态扩展对象功能,避免子类爆炸。文章通过Java示例展示两者在GUI、IO流、Web中间件等场景的应用,并提供常见陷阱与面试高频问题解析,助你写出灵活、可维护的代码。
|
设计模式 Java Apache
【设计模式】【创建型模式】建造者模式(Builder)
一、入门 什么是建造者模式? 建造者模式(Builder Pattern)是一种创建型设计模式,用于逐步构建复杂对象。 它通过将对象的构建过程与表示分离,使得相同的构建过程可以创建不同的表示。 为什么
771 14
|
8月前
|
设计模式 算法 搜索推荐
Java 设计模式之策略模式:灵活切换算法的艺术
策略模式通过封装不同算法并实现灵活切换,将算法与使用解耦。以支付为例,微信、支付宝等支付方式作为独立策略,购物车根据选择调用对应支付逻辑,提升代码可维护性与扩展性,避免冗长条件判断,符合开闭原则。
2193 35
|
8月前
|
设计模式 消息中间件 传感器
Java 设计模式之观察者模式:构建松耦合的事件响应系统
观察者模式是Java中常用的行为型设计模式,用于构建松耦合的事件响应系统。当一个对象状态改变时,所有依赖它的观察者将自动收到通知并更新。该模式通过抽象耦合实现发布-订阅机制,广泛应用于GUI事件处理、消息通知、数据监控等场景,具有良好的可扩展性和维护性。
606 8
|
设计模式 缓存 安全
【高薪程序员必看】万字长文拆解Java并发编程!(8):设计模式-享元模式设计指南
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中的经典对象复用设计模式-享元模式,废话不多说让我们直接开始。
258 0
|
10月前
|
设计模式 安全 Java
Java设计模式(一):单例模式与工厂模式
本文详解单例模式与工厂模式的核心实现及应用,涵盖饿汉式、懒汉式、双重检查锁、工厂方法、抽象工厂等设计模式,并结合数据库连接池与支付系统实战案例,助你掌握设计模式精髓,提升代码专业性与可维护性。
|
10月前
|
设计模式 XML 安全
Java枚举(Enum)与设计模式应用
Java枚举不仅是类型安全的常量,还具备面向对象能力,可添加属性与方法,实现接口。通过枚举能优雅实现单例、策略、状态等设计模式,具备线程安全、序列化安全等特性,是编写高效、安全代码的利器。
|
设计模式 Java 数据安全/隐私保护
Java 设计模式:装饰者模式(Decorator Pattern)
装饰者模式属于结构型设计模式,允许通过动态包装对象的方式为对象添加新功能,提供比继承更灵活的扩展方式。该模式通过组合替代继承,遵循开闭原则(对扩展开放,对修改关闭)。