当前位置: 首页 > news >正文

Java创建型模式---工厂模式

工厂模式基础概念

工厂模式是一种创建型设计模式,其核心思想是将对象的创建和使用分离。通过使用工厂模式,可以将对象创建逻辑集中管理,提高代码的可维护性和可扩展性。在 Java 中,工厂模式主要分为三种类型:

  1. 简单工厂模式 - 基础实现,不属于 GOF 23 种设计模式
  2. 工厂方法模式 - 定义创建对象的接口,由子类决定实例化哪个类
  3. 抽象工厂模式 - 创建一系列相关或依赖对象的接口,无需指定具体类

简单工厂模式

简单工厂模式是工厂模式的基础实现,它定义了一个创建对象的类,根据参数的不同返回不同类的实例。

示例代码
// 产品接口
interface Product {void operation();
}// 具体产品类A
class ConcreteProductA implements Product {@Overridepublic void operation() {System.out.println("ConcreteProductA operation");}
}// 具体产品类B
class ConcreteProductB implements Product {@Overridepublic void operation() {System.out.println("ConcreteProductB operation");}
}// 简单工厂类
class SimpleFactory {public static Product createProduct(String type) {switch (type) {case "A":return new ConcreteProductA();case "B":return new ConcreteProductB();default:throw new IllegalArgumentException("Invalid product type: " + type);}}
}// 客户端代码
public class SimpleFactoryClient {public static void main(String[] args) {Product productA = SimpleFactory.createProduct("A");productA.operation(); // 输出: ConcreteProductA operationProduct productB = SimpleFactory.createProduct("B");productB.operation(); // 输出: ConcreteProductB operation}
}

优点:实现简单,将对象创建和使用分离
缺点:工厂类职责过重,不符合开闭原则(新增产品需修改工厂类)

工厂方法模式

工厂方法模式定义了一个创建对象的接口,让子类决定实例化哪个类。工厂方法将类的实例化延迟到子类。

示例代码
// 产品接口
interface Product {void operation();
}// 具体产品类A
class ConcreteProductA implements Product {@Overridepublic void operation() {System.out.println("ConcreteProductA operation");}
}// 具体产品类B
class ConcreteProductB implements Product {@Overridepublic void operation() {System.out.println("ConcreteProductB operation");}
}// 抽象工厂类
abstract class Factory {public abstract Product createProduct();
}// 具体工厂类A - 生产产品A
class ConcreteFactoryA extends Factory {@Overridepublic Product createProduct() {return new ConcreteProductA();}
}// 具体工厂类B - 生产产品B
class ConcreteFactoryB extends Factory {@Overridepublic Product createProduct() {return new ConcreteProductB();}
}// 客户端代码
public class FactoryMethodClient {public static void main(String[] args) {Factory factoryA = new ConcreteFactoryA();Product productA = factoryA.createProduct();productA.operation(); // 输出: ConcreteProductA operationFactory factoryB = new ConcreteFactoryB();Product productB = factoryB.createProduct();productB.operation(); // 输出: ConcreteProductB operation}
}

优点:符合开闭原则,扩展性好
缺点:类的数量可能过多,增加系统复杂度

抽象工厂模式

抽象工厂模式提供一个创建一系列相关或依赖对象的接口,而无需指定它们具体的类。

示例代码
// 产品A接口
interface ProductA {void operationA();
}// 产品B接口
interface ProductB {void operationB();
}// 具体产品A1
class ConcreteProductA1 implements ProductA {@Overridepublic void operationA() {System.out.println("ConcreteProductA1 operationA");}
}// 具体产品A2
class ConcreteProductA2 implements ProductA {@Overridepublic void operationA() {System.out.println("ConcreteProductA2 operationA");}
}// 具体产品B1
class ConcreteProductB1 implements ProductB {@Overridepublic void operationB() {System.out.println("ConcreteProductB1 operationB");}
}// 具体产品B2
class ConcreteProductB2 implements ProductB {@Overridepublic void operationB() {System.out.println("ConcreteProductB2 operationB");}
}// 抽象工厂接口
interface AbstractFactory {ProductA createProductA();ProductB createProductB();
}// 具体工厂1 - 生产产品A1和产品B1
class ConcreteFactory1 implements AbstractFactory {@Overridepublic ProductA createProductA() {return new ConcreteProductA1();}@Overridepublic ProductB createProductB() {return new ConcreteProductB1();}
}// 具体工厂2 - 生产产品A2和产品B2
class ConcreteFactory2 implements AbstractFactory {@Overridepublic ProductA createProductA() {return new ConcreteProductA2();}@Overridepublic ProductB createProductB() {return new ConcreteProductB2();}
}// 客户端代码
public class AbstractFactoryClient {public static void main(String[] args) {// 使用工厂1创建产品族1AbstractFactory factory1 = new ConcreteFactory1();ProductA productA1 = factory1.createProductA();ProductB productB1 = factory1.createProductB();productA1.operationA(); // 输出: ConcreteProductA1 operationAproductB1.operationB(); // 输出: ConcreteProductB1 operationB// 使用工厂2创建产品族2AbstractFactory factory2 = new ConcreteFactory2();ProductA productA2 = factory2.createProductA();ProductB productB2 = factory2.createProductB();productA2.operationA(); // 输出: ConcreteProductA2 operationAproductB2.operationB(); // 输出: ConcreteProductB2 operationB}
}

优点

  • 可以在类的内部对产品族中相关联的多等级产品共同管理
  • 客户端始终只使用一个工厂的对象
  • 符合开闭原则

缺点

  • 产品族扩展困难(新增一个产品需要修改多个接口和类)
  • 实现复杂

三种工厂模式的对比

类型工厂职责产品等级结构扩展性
简单工厂模式集中所有产品创建单一等级不符合开闭原则
工厂方法模式由子类负责创建单一等级符合开闭原则
抽象工厂模式创建一系列产品多个等级(产品族)产品族扩展困难

工厂模式的应用场景

  1. 对象创建逻辑复杂 - 当对象创建过程涉及复杂的初始化逻辑时
  2. 根据条件动态创建对象 - 如根据配置或用户输入创建不同类型的对象
  3. 产品等级结构管理 - 当系统需要处理多个产品族时

注意事项

  1. 避免过度使用 - 简单场景下无需使用工厂模式
  2. 权衡设计复杂度 - 选择合适的工厂模式类型
  3. 与其他模式结合 - 工厂模式常与单例模式、策略模式等结合使用

工厂模式是一种非常实用的设计模式,它能够将对象的创建和使用分离,提高代码的可维护性和可扩展性。在实际应用中,需要根据具体场景选择合适的工厂模式实现。

http://www.dtcms.com/a/267590.html

相关文章:

  • java多线程--死锁
  • CppCon 2018 学习:Standard Library Compatibility Guidelines (SD-8)
  • 未成功,做个记录,SelfHost.HttpSelfHostServer 如何加载证书
  • 【Prometheus】Grafana、Alertmanager集成
  • 小架构step系列05:Springboot三种运行模式
  • 理想汽车6月交付36279辆 第二季度共交付111074辆
  • 基于微信小程序的校园跑腿系统
  • MySQL——9、事务管理
  • Java-继承
  • 远程协助软件:Git的用法
  • STM32第15天串口中断接收
  • 数据结构:数组抽象数据类型(Array ADT)
  • oracle的内存架构学习
  • Hashcat 最快密码恢复工具实践指南
  • jvm架构原理剖析篇
  • C++ Qt 基础教程:信号与槽机制详解及 QPushButton 实战
  • virtualbox+vagrant私有网络宿主机无法ping通虚拟机问题请教
  • Apache 配置文件提权的实战思考
  • 数据库-元数据表
  • docker容器中Mysql数据库的备份与恢复
  • Java的AI新纪元:Embabel如何引领智能应用开发浪潮
  • 一文讲清楚React中setState的使用方法和机制
  • 应用标签思路参考
  • wsl查看磁盘文件并清理空间
  • Django跨域
  • 什么是单点登录SSO?有哪些常用的实现方式?
  • Android PNG/JPG图ARGB_8888/RGB_565‌解码形成Bitmap在物理内存占用大小的简单计算
  • SpringBoot系列—入门
  • ffplay6 播放器关键技术点分析 1/2
  • NumPy-核心函数np.matmul()深入解析