Java设计模式:建造者模式详解

简介: 建造者模式是一种创建型设计模式,通过将复杂对象的构建过程与表示分离,使得相同的构建过程可以创建不同的表示。本文详细介绍了建造者模式的原理、背景、应用场景及实际Demo,帮助读者更好地理解和应用这一模式。

建造者模式(Builder Pattern)是一种创建型设计模式,其核心思想是通过将复杂对象的构建过程与表示分离,使得同样的构建过程可以创建不同的表示。建造者模式提供了一种灵活的方式来构建复杂对象,从而提高代码的可读性和可维护性。

本文将从建造者模式的原理、背景、应用场景以及实际Demo等多个角度来详细介绍建造者模式。

一、建造者模式的原理

建造者模式的主要目标是将对象的构建过程封装起来,使得客户端代码能够通过简单的接口构建复杂对象。在建造者模式中,核心是提供一个建造者接口和多个具体建造者类,具体建造者类负责创建产品的不同部分,最终由指挥者类协调各个建造者完成对象的构建。其基本结构如下:

  • 产品(Product) :表示要创建的复杂对象,包含多个组成部分。
  • 建造者(Builder) :定义创建产品的抽象接口,声明构建产品各个部分的方法。
  • 具体建造者(ConcreteBuilder) :实现建造者接口,提供构建产品的具体实现。
  • 指挥者(Director) :负责控制建造过程,按照特定的顺序调用建造者的方法。

二、建造者模式的背景

在面向对象编程中,当一个对象的构建过程涉及多个步骤时,传统的构造函数方式可能导致代码变得复杂且难以维护。尤其是在需要多个可选参数的情况下,构造函数可能会变得冗长,影响代码的可读性。建造者模式通过将构建过程分离,使得创建复杂对象变得更加清晰和灵活,符合开闭原则(对扩展开放、对修改关闭)。

三、建造者模式的应用场景

建造者模式适用于以下几种场景:

  • 复杂对象的构建:当对象的构建需要多个步骤,且步骤之间有依赖关系时,建造者模式能够简化构建过程。
  • 多个可选参数:当对象的构造需要多个可选参数时,使用建造者模式可以避免构造函数参数过多的问题。
  • 不同表现形式的对象:当需要构建的对象具有多种不同表现时,建造者模式可以通过不同的建造者创建不同的对象实例。

四、建造者模式的分类及实现

建造者模式通常没有严格的分类,其实现通常围绕一个产品类和多个建造者类展开。以下是一个简单的建造者模式实现示例:

1. 定义产品类

typescript

代码解读

复制代码

java
复制代码
// 产品类
class House {
    private String foundation;
    private String walls;
    private String roof;
    private int floors;

    public void setFoundation(String foundation) {
        this.foundation = foundation;
    }

    public void setWalls(String walls) {
        this.walls = walls;
    }

    public void setRoof(String roof) {
        this.roof = roof;
    }

    public void setFloors(int floors) {
        this.floors = floors;
    }

    @Override
    public String toString() {
        return "House{" +
                "foundation='" + foundation + ''' +
                ", walls='" + walls + ''' +
                ", roof='" + roof + ''' +
                ", floors=" + floors +
                '}';
    }
}

2. 定义建造者接口

csharp

代码解读

复制代码

java
复制代码
// 建造者接口
interface HouseBuilder {
    void buildFoundation();
    void buildWalls();
    void buildRoof();
    void buildFloors(int floors);
    House build();
}

3. 创建具体建造者实现

typescript

代码解读

复制代码

java
复制代码
// 具体建造者
class ConcreteHouseBuilder implements HouseBuilder {
    private House house;

    public ConcreteHouseBuilder() {
        this.house = new House();
    }

    @Override
    public void buildFoundation() {
        house.setFoundation("Concrete Foundation");
    }

    @Override
    public void buildWalls() {
        house.setWalls("Brick Walls");
    }

    @Override
    public void buildRoof() {
        house.setRoof("Gable Roof");
    }

    @Override
    public void buildFloors(int floors) {
        house.setFloors(floors);
    }

    @Override
    public House build() {
        return house;
    }
}

4. 定义指挥者类

csharp

代码解读

复制代码

java
复制代码
// 指挥者类
class HouseDirector {
    private HouseBuilder builder;

    public HouseDirector(HouseBuilder builder) {
        this.builder = builder;
    }

    public House constructHouse() {
        builder.buildFoundation();
        builder.buildWalls();
        builder.buildRoof();
        builder.buildFloors(2); // 默认构建2层
        return builder.build();
    }
}

5. 客户端代码

ini

代码解读

复制代码

java
复制代码
public class Main {
    public static void main(String[] args) {
        HouseBuilder builder = new ConcreteHouseBuilder();
        HouseDirector director = new HouseDirector(builder);
        
        House house = director.constructHouse();
        System.out.println(house);
    }
}

五、建造者模式的实际应用Demo

以一个餐厅的订单系统为例,顾客可以通过不同的选项来定制他们的餐点,使用建造者模式可以根据顾客的选择构建不同的餐点。

typescript

代码解读

复制代码

java
复制代码
// 餐点类
class Meal {
    private String mainCourse;
    private String drink;
    private String dessert;

    public void setMainCourse(String mainCourse) {
        this.mainCourse = mainCourse;
    }

    public void setDrink(String drink) {
        this.drink = drink;
    }

    public void setDessert(String dessert) {
        this.dessert = dessert;
    }

    @Override
    public String toString() {
        return "Meal{" +
                "mainCourse='" + mainCourse + ''' +
                ", drink='" + drink + ''' +
                ", dessert='" + dessert + ''' +
                '}';
    }
}

// 建造者接口
interface MealBuilder {
    void buildMainCourse(String mainCourse);
    void buildDrink(String drink);
    void buildDessert(String dessert);
    Meal build();
}

// 具体建造者
class ConcreteMealBuilder implements MealBuilder {
    private Meal meal;

    public ConcreteMealBuilder() {
        this.meal = new Meal();
    }

    @Override
    public void buildMainCourse(String mainCourse) {
        meal.setMainCourse(mainCourse);
    }

    @Override
    public void buildDrink(String drink) {
        meal.setDrink(drink);
    }

    @Override
    public void buildDessert(String dessert) {
        meal.setDessert(dessert);
    }

    @Override
    public Meal build() {
        return meal;
    }
}

// 指挥者类
class MealDirector {
    private MealBuilder builder;

    public MealDirector(MealBuilder builder) {
        this.builder = builder;
    }

    public Meal constructMeal(String mainCourse, String drink, String dessert) {
        builder.buildMainCourse(mainCourse);
        builder.buildDrink(drink);
        builder.buildDessert(dessert);
        return builder.build();
    }
}

使用示例

在实际应用中,可以根据顾客的选择构建不同的餐点:

java

代码解读

复制代码

java
复制代码
public class Client {
    public static void main(String[] args) {
        MealBuilder builder = new ConcreteMealBuilder();
        MealDirector director = new MealDirector(builder);
        
        Meal meal = director.constructMeal("Steak", "Wine", "Cheesecake");
        System.out.println(meal); // 输出:Meal{mainCourse='Steak', drink='Wine', dessert='Cheesecake'}
    }
}

总结

建造者模式通过将复杂对象的构建过程进行抽象和模块化,使得对象的创建更加灵活和可控。它不仅提高了代码的可读性和可维护性,还能在对象构建过程中支持不同的表现形式。掌握建造者模式在处理复杂对象创建时非常有用,能够显著提升代码质量和开发效率。


转载来源:https://juejin.cn/post/7426647926589882419

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