news 2026/3/26 12:12:20

工厂模式详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
工厂模式详解

在设计模式中,工厂模式属于创建型模式,核心是封装对象的创建过程,降低代码耦合度。根据抽象程度和应用场景的不同,工厂模式主要分为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(); // 输出:生产苹果电脑 } }

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

四、三种工厂模式的对比

模式类型核心思想适用场景开闭原则兼容性
简单工厂模式单一工厂类 + 静态方法创建产品产品类型少、固定不兼容
工厂方法模式一个产品对应一个工厂类产品类型多、需频繁扩展兼容(扩展产品)
抽象工厂模式一个工厂创建一族相关产品需创建关联产品族兼容(扩展产品族)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/26 7:38:54

基于人工智能的本科生论文格式规范化工具研究

核心工具对比速览 工具名称 核心功能 适用场景 效率评分 特色优势 aicheck 文献综述生成/格式检查 文献整理/格式规范 ★★★★☆ 自动整合文献观点,符合国内院校要求 aibiye 论文降重/格式优化 查重后修改/格式调整 ★★★★ 智能改写保留原意&#…

作者头像 李华
网站建设 2026/3/14 12:59:23

论文查重不过关?试试这些AI工具,快速降低重复率

五大降重工具核心对比 工具名称 处理速度 降重幅度 专业术语保留 适用场景 aicheck 20分钟内 40%→7% 完全保留 高重复率论文紧急处理 秒篇 5-10分钟 45%→8% 完全保留 快速降重需求 白果AI 15分钟 30%→10% 学科词库保护 学术论文精细降重 文赋AI 5分钟 …

作者头像 李华
网站建设 2026/3/13 0:20:28

终极指南:用OpenCore Legacy Patcher让老Mac焕发新生

终极指南:用OpenCore Legacy Patcher让老Mac焕发新生 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 还在为老Mac无法升级最新系统而苦恼吗?&#…

作者头像 李华
网站建设 2026/3/12 22:55:35

Java关键字解析之abstract:抽象的本质、规范定义与多态基石

前言 在Java面向对象的世界里,abstract是一个充满“前瞻性”的关键字——它像一张“设计蓝图”,将类或方法标记为“未完成”或“待实现”,强制后续开发者遵循预设的规范去填充细节。这种抽象性并非模糊不清,而是通过“定义标准、…

作者头像 李华
网站建设 2026/3/25 3:38:31

Mermaid在线编辑器新手入门指南:轻松制作专业图表

Mermaid在线编辑器新手入门指南:轻松制作专业图表 【免费下载链接】mermaid-live-editor Edit, preview and share mermaid charts/diagrams. New implementation of the live editor. 项目地址: https://gitcode.com/gh_mirrors/me/mermaid-live-editor 还在…

作者头像 李华
网站建设 2026/3/13 0:57:47

FPGA实战:一段让我重新认识时序收敛的FPGA迁移之旅

从Kintex-7到Versal:一段让我重新认识时序收敛的FPGA迁移之旅 摘要 :当一段在Kintex-7上稳定运行多年的MIPI Rx代码,迁移到Versal后开始随机出错,我没想到问题竟隐藏在一个看似"安全"的buffer逻辑中。这是一个关于时钟域…

作者头像 李华