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

工厂模式详解

在设计模式中,工厂模式属于创建型模式,核心是封装对象的创建过程,降低代码耦合度。根据抽象程度和应用场景的不同,工厂模式主要分为3 种,由简单到复杂依次是:

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

核心特点

  • 不属于 GoF 23 种经典设计模式,是一种 “简易实现”,也叫静态工厂模式
  • 定义一个工厂类,通过静态方法接收参数,根据参数类型创建不同的产品实例。
  • 产品类需要继承同一个抽象产品类或实现同一个接口。

适用场景:产品类型较少且相对固定,不需要频繁扩展新产品。

代码示例

// 抽象产品 public interface Phone { void make(); } // 具体产品1 public class IPhone implements Phone { @Override public void make() { System.out.println("生产苹果手机"); } } // 具体产品2 public class HuaweiPhone implements Phone { @Override public void make() { System.out.println("生产华为手机"); } } // 简单工厂类 public class PhoneFactory { // 静态工厂方法 public static Phone createPhone(String type) { if ("iphone".equals(type)) { return new IPhone(); } else if ("huawei".equals(type)) { return new HuaweiPhone(); } throw new IllegalArgumentException("不支持的手机类型"); } } // 测试 public class Test { public static void main(String[] args) { Phone iphone = PhoneFactory.createPhone("iphone"); iphone.make(); // 输出:生产苹果手机 } }

缺点:新增产品时需要修改工厂类的代码,违反开闭原则

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

核心特点

  • 属于 GoF 23 种经典设计模式。
  • 定义一个抽象工厂接口,每个具体产品对应一个具体工厂类,由具体工厂负责创建对应的产品实例。
  • 抽象工厂只定义创建产品的方法,具体实现交给子类。

适用场景:产品类型较多,且需要频繁扩展新的产品,符合开闭原则。

代码示例

// 抽象产品 public interface Phone { void make(); } // 具体产品1 public class IPhone implements Phone { @Override public void make() { System.out.println("生产苹果手机"); } } // 具体产品2 public class HuaweiPhone implements Phone { @Override public void make() { System.out.println("生产华为手机"); } } // 抽象工厂 public interface PhoneFactory { Phone createPhone(); } // 具体工厂1:生产苹果手机 public class IPhoneFactory implements PhoneFactory { @Override public Phone createPhone() { return new IPhone(); } } // 具体工厂2:生产华为手机 public class HuaweiFactory implements PhoneFactory { @Override public Phone createPhone() { return new HuaweiPhone(); } } // 测试 public class Test { public static void main(String[] args) { PhoneFactory factory = new IPhoneFactory(); Phone phone = factory.createPhone(); phone.make(); // 输出:生产苹果手机 } }

优点:新增产品时只需添加对应的具体产品类具体工厂类,无需修改原有代码,符合开闭原则。缺点:产品和工厂成对增加,会导致类的数量增多,增加系统复杂度。

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

核心特点

  • 属于 GoF 23 种经典设计模式,是工厂方法模式的升级版本
  • 抽象工厂不仅创建一种产品,而是创建一族相关的产品(产品族),且产品之间通常存在关联或依赖关系。
  • 定义一个抽象工厂接口,包含多个创建不同产品的方法;每个具体工厂类负责创建同一产品族的所有产品实例。

适用场景:需要创建一组相关联的产品,且产品族的结构相对稳定。

代码示例(Java)

// --- 产品族1:手机 --- public interface Phone { void make(); } public class IPhone implements Phone { @Override public void make() { System.out.println("生产苹果手机"); } } public class HuaweiPhone implements Phone { @Override public void make() { System.out.println("生产华为手机"); } } // --- 产品族2:电脑 --- public interface Computer { void make(); } public class Mac implements Computer { @Override public void make() { System.out.println("生产苹果电脑"); } } public class MateBook implements Computer { @Override public void make() { System.out.println("生产华为电脑"); } } // --- 抽象工厂:生产电子设备族 --- public interface ElectronicFactory { Phone createPhone(); Computer createComputer(); } // --- 具体工厂1:苹果工厂(生产苹果手机+苹果电脑) --- public class AppleFactory implements ElectronicFactory { @Override public Phone createPhone() { return new IPhone(); } @Override public Computer createComputer() { return new Mac(); } } // --- 具体工厂2:华为工厂(生产华为手机+华为电脑) --- public class HuaweiFactory implements ElectronicFactory { @Override public Phone createPhone() { return new HuaweiPhone(); } @Override public Computer createComputer() { return new MateBook(); } } // 测试 public class Test { public static void main(String[] args) { ElectronicFactory factory = new AppleFactory(); Phone phone = factory.createPhone(); Computer computer = factory.createComputer(); phone.make(); // 输出:生产苹果手机 computer.make(); // 输出:生产苹果电脑 } }

优点:可以确保同一工厂生产的产品属于同一产品族,避免不兼容的产品组合。缺点:新增产品族时符合开闭原则,但新增产品类型(如在电子设备中新增平板)时,需要修改抽象工厂和所有具体工厂的代码,违反开闭原则。

四、三种工厂模式的对比

模式类型核心思想适用场景开闭原则兼容性
简单工厂模式单一工厂类 + 静态方法创建产品产品类型少、固定不兼容
工厂方法模式一个产品对应一个工厂类产品类型多、需频繁扩展兼容(扩展产品)
抽象工厂模式一个工厂创建一族相关产品需创建关联产品族兼容(扩展产品族)
http://www.cnnetsun.cn/news/53846.html

相关文章:

  • JVM G1 和 CMS 详解与对比
  • 实战解析:2PC与Saga分布式事务的完全避坑指南
  • Lumafly模组管理器:重构空洞骑士模组生态的专业解决方案
  • 12.14 - 搜索旋转排序数组 判断两个结构体是否相等
  • WaveTools鸣潮120帧解锁与游戏性能优化全攻略
  • 三步学会百度网盘极速下载:告别龟速的终极方案
  • 5大实用技巧:用Calibre-Douban插件智能管理电子书元数据
  • 飞书文档批量导出终极指南:一键解决文档迁移难题
  • Source Han Serif思源宋体:免费开源中文字体专业应用指南
  • DOM Element:深入理解与操作
  • 深度解析 Flutter 路由管理:从原生路由到 AutoRoute 的优雅升级与性能优化
  • Turnitin系统查英文AI率多少为正常?报告显示星号*%怎么办?
  • 暖通净化空调恒温恒湿项目:PLC 与触摸屏上位机程序探秘
  • 第30章 Shell 正则表达式实战:精准匹配字符串、日志与配置项
  • 音视频学习(七十二):视频压缩:分块与预处理
  • AMD Ryzen性能调优:快速掌握处理器调试工具的使用技巧
  • 深蓝词库转换:轻松打通全平台输入法数据壁垒
  • (新卷,200分)- 最小传输时延Ⅱ(Java JS Python)
  • OpenHarmony AI人脸识别与手势控制系统开发指南
  • 新一代空间感知驱动的军工仓库与硐室透明化管控技术研究
  • Sketch MeaXure插件:设计师必备的智能标注工具
  • 强化学习Q-learning求最优策略
  • 你对电脑上的【Fn】熟悉多少
  • 计及N-k安全约束的含光热电站电力系统优化调度模型【IEEE14节点、118节点】附Matlab代码
  • 计及需求响应的粒子群算法求解风能、光伏、柴油机、储能容量优化配置附Matlab代码
  • conda使用详细指南
  • 豆包与DeepSeek底层大模型的深度解析:技术架构、设计理念与生态分野
  • Linux系统中的socket激活:先创建监听端口,后启动程序
  • 从零解决pyproject.toml构建失败的实战指南
  • Redis Lua脚本入门:从零写出你的第一个原子操作