「全网最细 + 实战源码案例」设计模式——工厂方法模式

核心思想

  • 简单工厂模式是一种创建者模式,它通过一个工厂类负责创建不同类型的对象,根据传入的参数决定实例化的具体类,也被称为"静态工厂方法"模式,因为工厂方法通常是静态的。

结构

1. 工厂类:

  • 提供一个静态方法,根据不同条件创建并返回具体的产品对象。

2. 产品接口(抽象类)

  • 定义产品的通用行为。

3. 具体产品类

  • 工厂根据条件创建的具体实例。

适用场景

1. 创建的对象种类少。

2. 调用者不需要关心具体产品类的创建细节。


优缺点

优点:

1.1. 封装性强:调用者无需知道产品类的具体实现细节,只需通过工厂类获取产品对象。

1.2. 代码复用:将对象的创建逻辑集中在工厂类中,避免重复代码。

缺点:

1.1. 扩展性差:增加新产品时需要修改工厂类代码,违反开闭原则(OCP)。

1.2. 职责集中:工厂类集中了所有产品的创建逻辑,可能导致类的职责过重。


示例


与其他模式的关系

相关推荐
bingbingyihao12 分钟前
多数据源 Demo
java·springboot
饕餮争锋1 小时前
设计模式笔记_行为型_访问者模式
笔记·设计模式·访问者模式
在努力的前端小白5 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
bobz9657 小时前
小语言模型是真正的未来
后端
一叶飘零_sweeeet7 小时前
从繁琐到优雅:Java Lambda 表达式全解析与实战指南
java·lambda·java8
DevYK8 小时前
企业级 Agent 开发实战(一) LangGraph 快速入门
后端·llm·agent
艾伦~耶格尔8 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
一只叫煤球的猫8 小时前
🕰 一个案例带你彻底搞懂延迟双删
java·后端·面试
最初的↘那颗心8 小时前
Flink Stream API 源码走读 - print()
java·大数据·hadoop·flink·实时计算
冒泡的肥皂8 小时前
MVCC初学demo(一
数据库·后端·mysql