Java设计模式 简单工厂模式 工厂方法模式 抽象工厂模式 模版工厂模式 模式对比

目录

一、工厂模式(简单工厂模式)

[二、工厂方法模式(Factory Method)](#二、工厂方法模式(Factory Method))

[三、抽象工厂模式(Abstract Factory)](#三、抽象工厂模式(Abstract Factory))

四、模板工厂模式(特殊实现)

五、模式对比


一、工厂模式(简单工厂模式)

核心思想 :通过工厂类集中控制对象创建逻辑,隐藏对象实例化细节
实现方式

  1. 定义产品接口/抽象类

  2. 创建具体产品类

  3. 编写工厂类,通过静态方法根据输入参数创建对象

    // 产品接口
    interface Shape {
    void draw();
    }

    // 具体产品
    class Circle implements Shape {
    public void draw() { System.out.println("画圆形"); }
    }

    class Square implements Shape {
    public void draw() { System.out.println("画方形"); }
    }

    // 简单工厂
    class ShapeFactory {
    public static Shape createShape(String type) {
    return switch (type.toUpperCase()) {
    case "CIRCLE" -> new Circle();
    case "SQUARE" -> new Square();
    default -> throw new IllegalArgumentException();
    };
    }
    }

    // 使用
    Shape shape = ShapeFactory.createShape("CIRCLE");

特点

  • ✅ 客户端与具体类解耦
  • ❌ 违反开闭原则(新增类型需修改工厂)

二、工厂方法模式(Factory Method)

核心思想 :定义创建对象的抽象方法,由子类决定实例化的类
实现方式

  1. 定义抽象工厂类

  2. 每个产品对应具体工厂子类

    // 抽象工厂
    abstract class Dialog {
    abstract Button createButton();

    复制代码
     void render() {
         Button button = createButton();
         button.render();
     }

    }

    // 具体工厂
    class WindowsDialog extends Dialog {
    Button createButton() { return new WindowsButton(); }
    }

    class WebDialog extends Dialog {
    Button createButton() { return new HTMLButton(); }
    }

    // 产品体系
    interface Button {
    void render();
    }

    class WindowsButton implements Button {
    public void render() { System.out.println("Windows风格按钮"); }
    }

    class HTMLButton implements Button {
    public void render() { System.out.println("Web风格按钮"); }
    }

特点

  • ✅ 符合开闭原则
  • ✅ 支持多态性
  • ❌ 类数量膨胀

三、抽象工厂模式(Abstract Factory)

核心思想 :创建相关或依赖对象的家族,无需指定具体类
典型场景:跨平台UI组件、数据库访问套件

复制代码
// 抽象工厂
interface GUIFactory {
    Button createButton();
    Checkbox createCheckbox();
}

// 具体工厂(Windows风格)
class WinFactory implements GUIFactory {
    public Button createButton() { return new WinButton(); }
    public Checkbox createCheckbox() { return new WinCheckbox(); }
}

// 具体工厂(Mac风格)
class MacFactory implements GUIFactory {
    public Button createButton() { return new MacButton(); }
    public Checkbox createCheckbox() { return new MacCheckbox(); }
}

// 产品体系
interface Button { void paint(); }
interface Checkbox { void check(); }

class WinButton implements Button {
    public void paint() { System.out.println("Windows按钮"); }
}
class MacCheckbox implements Checkbox {
    public void check() { System.out.println("Mac复选框"); }
}

特点

  • ✅ 保证产品兼容性
  • ✅ 产品族一致性控制
  • ❌ 扩展新产品族困难

四、模板工厂模式(特殊实现)

混合模式 :结合模板方法模式与工厂模式
典型实现

  1. 定义包含模板方法的抽象工厂

  2. 子类实现具体步骤

    abstract class DocumentConverter {
    // 模板方法
    public final void convert() {
    loadDocument();
    parseContent();
    saveOutput();
    }

    复制代码
     abstract void loadDocument();
     abstract void parseContent();
     abstract void saveOutput();

    }

    class PDFConverter extends DocumentConverter {
    void loadDocument() { /* PDF加载逻辑 / }
    void parseContent() { /
    解析PDF / }
    void saveOutput() { /
    输出处理 */ }
    }

适用场景:需要固定流程但步骤实现不同的场景


五、模式对比

|------|----------|-------------|
| 模式 | 核心差异 | 最佳场景 |
| 简单工厂 | 集中式对象创建 | 创建逻辑简单的少量对象 |
| 工厂方法 | 子类决定对象类型 | 需要扩展单个产品类型 |
| 抽象工厂 | 创建产品家族 | 需要保证多产品兼容性 |

相关推荐
一路往蓝-Anbo3 小时前
第三篇:ADC 与模拟前端
stm32·嵌入式硬件·嵌入式·硬件设计
yaoxin5211233 小时前
434. Java 日期时间 API - Period 基于日期的时间段
java·开发语言·python
毒爪的小新3 小时前
Linux 环境极速部署 vLLM:从零搭建生产级大模型推理服务
linux·人工智能·ai·语言模型·vllm
鹤落晴春3 小时前
RH124问答3:从命令行管理文件
linux·运维·服务器
凡人叶枫3 小时前
Effective C++ 条款30:透彻了解 inlining 的里里外外
linux·开发语言·c++·嵌入式开发·effective c++
guslegend4 小时前
大模型驱动大数据SRE智能运维
大数据·运维
何极光4 小时前
IDEA集成Maven
java·maven·intellij-idea
遇见火星4 小时前
Docker Compose 完全入门:一键启动所有容器
运维·docker·容器·docker compose
火山上的企鹅4 小时前
Codex实战:APP远程升级服务搭建(三)后台管理页面(APK 上传、版本管理、多应用页签)
服务器·网络·数据库·oracle·qgc
程序员二叉4 小时前
【JUC】ThreadLocal底层原理|内存泄漏|弱引用|跨线程传递方案
java·开发语言·面试·职场和发展·juc