建造者模式 + 抽象工厂模式
建造者模式(Builder Pattern)和抽象工厂模式(Abstract Factory Pattern)是两种常用的创建型设计模式,它们各自有不同的应用场景和优势。将这两者结合使用,可以帮助我们在构建复杂对象时更好地管理产品的创建过程,尤其是在需要管理多个产品组或者具有复杂构建步骤的场景下。
-
建造者模式(Builder Pattern)专注于逐步构建一个复杂的对象。它通过将构建过程与表示分离,使得同样的构建过程可以创建不同的表示。
-
抽象工厂模式(Abstract Factory Pattern)提供一个接口,用于创建一系列相关或依赖的对象,但不需要明确指定具体的类。抽象工厂通常用于创建一组相关的产品对象,如UI组件、操作系统控件等。
将这两者结合使用时,可以利用抽象工厂来管理多个产品族的创建,而使用建造者模式来构建每个具体产品的复杂部分。这种组合适合于产品包含多个子组件且子组件之间有复杂的构建关系时。
1. 场景说明
结合建造者模式和抽象工厂模式的场景通常出现在以下情况:
- 需要构建复杂的产品,且该产品的构建过程包含多个步骤: 如有多个相互关联的组件或模块,构建这些组件的过程较为复杂。
- 产品族: 需要创建多个不同类型的产品组(如不同风格的房子、不同操作系统下的UI控件等),每个产品组内有多个组件,且构建过程不完全相同。
- 构建过程与产品族相关: 不同产品族的构建步骤可能会有所不同,但每个族内的构建步骤是一致的。
2. 示例场景:创建多种类型的房子
假设我们有一个房屋构建系统,能够创建不同风格的房子(如现代风格和古典风格),每种风格的房子包含不同的组件(如门、窗、屋顶等)。我们可以使用抽象工厂模式来管理不同风格的房子工厂,而使用建造者模式来构建房子的不同部分(如门、窗、屋顶等)。
(1) 房子的组件接口
首先,我们定义房子的各个组件(如门、窗、屋顶等)的接口。
// 门接口
public interface Door {
void build();
}
// 窗口接口
public interface Window {
void build();
}
// 屋顶接口
public interface Roof {
void build();
}
(2) 具体组件实现:现代风格和古典风格
根据风格的不同,门、窗、屋顶的实现也有所不同。
// 现代风格的门
public class ModernDoor implements Door {
@Override
public void build() {
System.out.println("Building a modern door.");
}
}
// 现代风格的窗
public class ModernWindow implements Window {
@Override
public void build() {
System.out.println("Building a modern window.");
}
}
// 现代风格的屋顶
public class ModernRoof implements Roof {
@Override
public void build() {
System.out.println("Building a modern roof.");
}
}
// 古典风格的门
public class ClassicalDoor implements Door