重温设计模式--工厂模式(简单、工厂、抽象)

server/2024/12/27 10:12:12/

文章目录

  • 工厂模式定义
  • 工厂模式通常可以细分为以下几种类型
    • 1、简单工厂模式(Simple Factory Pattern)
    • 2、工厂方法模式(Factory Method Pattern)
    • 3、抽象工厂模式(Abstract Factory Pattern)
  • UML 图
    • 1、简单工厂模式UML
    • 2、工厂模式UML
    • 3、抽象工厂模式UML
  • C++ 代码示例。
    • 1、简单工厂模式
      • 结构及原理
        • 简单工厂模式包含以下几个关键部分:
    • 工厂方法模式
      • 结构及原理
        • 工厂方法模式在简单工厂模式基础上做了如下改变:
  • 抽象工厂模式
    • 结构及原理
    • C++ 代码示例
  • 总结

工厂模式定义

工厂模式(Factory Pattern)属于创建型设计模式,它主要用于对象的创建过程,将对象的创建和使用分离,把对象创建的逻辑封装在工厂类中,这样当需要创建对象时,不用在客户端代码里直接通过 new 操作符等去实例化对象,而是通过调用工厂类的相应方法来获取对象。这使得代码的维护性和可扩展性更好,也提高了代码的灵活性和可复用性。

工厂模式通常可以细分为以下几种类型

1、简单工厂模式(Simple Factory Pattern)

它是工厂模式的基础,虽然严格来说不算 GoF(Gang of Four,设计模式四人组)提出的 23 种设计模式之一,但却是理解工厂模式的重要起点。简单工厂模式有一个工厂类,该工厂类根据传入的参数等条件来决定创建哪种具体产品对象。

2、工厂方法模式(Factory Method Pattern)

在简单工厂模式上进行了改进,把具体产品对象的创建方法延迟到具体的工厂子类中实现,工厂类变成抽象类,有一个抽象的创建方法,每个具体的工厂子类负责创建对应的具体产品对象,符合开闭原则(对扩展开放,对修改关闭)。

3、抽象工厂模式(Abstract Factory Pattern)

更为复杂和抽象,工厂类负责创建一系列相关的产品对象,客户端调用抽象工厂类的抽象创建方法,由具体的工厂子类来创建符合特定需求的一组相关产品,常用于创建一组有内在关联、需要统一创建的对象场景。

UML 图

1、简单工厂模式UML

在这里插入图片描述

2、工厂模式UML

在这里插入图片描述

3、抽象工厂模式UML

在这里插入图片描述

C++ 代码示例。

1、简单工厂模式

结构及原理

简单工厂模式包含以下几个关键部分:

抽象产品(Product):定义产品对象的接口,描述了产品共有的行为和属性。
具体产品(ConcreteProduct):实现抽象产品接口,代表具体的产品对象,不同的具体产品有其独特的实现逻辑。
工厂类(Factory):负责创建具体的产品对象,根据传入的条件或者参数决定实例化哪种具体产品。
C++ 代码示例

#include <iostream>
#include <string>// 抽象产品
class Product
{
public:virtual void use() = 0;virtual ~Product() {}
};// 具体产品A
class ConcreteProductA : public Product 
{
public:void use() override {std::cout << "Using ConcreteProductA" << std::endl;}
};// 具体产品B
class ConcreteProductB : public Product
{
public:void use() override{std::cout << "Using ConcreteProductB" << std::endl;}
};// 工厂类
class Factory
{
public:static Product* createProduct(const std::string& type){if (type == "A"){return new ConcreteProductA();}else if (type == "B"){return new ConcreteProductB();}return nullptr;}
};int main()
{Product* productA = Factory::createProduct("A");Product* productB = Factory::createProduct("B");if (productA){productA->use();delete productA;}if (productB){productB->use();delete productB;}char t;std::cin>>t;return 0;
}

在上述代码中:
Product 是抽象产品类,定义了 use 这个抽象方法,代表产品被使用时的操作。
ConcreteProductA 和 ConcreteProductB 是具体产品类,分别实现了 use 方法,有着各自不同的使用逻辑。
Factory 是工厂类,其 createProduct 静态方法根据传入的产品类型字符串来决定创建哪种具体产品对象,然后返回给客户端使用。在 main 函数中,通过工厂类创建了不同的产品对象并调用它们的 use 方法展示功能,最后记得释放内存,避免内存泄漏。

工厂方法模式

结构及原理

工厂方法模式在简单工厂模式基础上做了如下改变:

抽象工厂(Abstract Factory):作为工厂类的抽象,定义了抽象的创建产品的方法,具体的创建逻辑延迟到具体工厂子类中。
具体工厂(Concrete Factory):继承自抽象工厂,实现抽象的创建方法,负责创建对应的具体产品对象。
在简单工厂模式的基础上,把对象的创建分布在各个产品对应的工厂内,而不是在一个工厂内,更加符合开闭原则,简单工厂模式严格来说不符合开闭原则,因为他对修改还是开放的
C++ 代码示例

#include <iostream>
#include <string>// 抽象产品
class Product 
{
public:virtual void use() = 0;virtual ~Product() {}
};// 具体产品A
class ConcreteProductA : public Product 
{
public:void use() override{std::cout << "Using ConcreteProductA" << std::endl;}
};// 具体产品B
class ConcreteProductB : public Product 
{
public:void use() override {std::cout << "Using ConcreteProductB" << std::endl;}
};// 抽象工厂
class AbstractFactory
{
public:virtual Product* createProduct() = 0;virtual ~AbstractFactory() {}
};// 具体工厂A,负责创建产品A
class ConcreteFactoryA : public AbstractFactory
{
public:Product* createProduct() override{return new ConcreteProductA();}
};// 具体工厂B,负责创建产品B
class ConcreteFactoryB : public AbstractFactory
{
public:Product* createProduct() override{return new ConcreteProductB();}
};int main()
{AbstractFactory* factoryA = new ConcreteFactoryA();AbstractFactory* factoryB = new ConcreteFactoryB();Product* productA = factoryA->createProduct();Product* productB = factoryB->createProduct();if (productA) {productA->use();delete productA;}if (productB){productB->use();delete productB;}delete factoryA;delete factoryB;return 0;
}

在这个代码中:
AbstractFactory 抽象工厂类定义了抽象的 createProduct 方法,让具体工厂子类去实现具体的创建逻辑。
ConcreteFactoryA 和 ConcreteFactoryB 分别是负责创建不同具体产品的具体工厂类,它们重写了 createProduct 方法来实例化对应的产品。在 main 函数中,先创建具体的工厂对象,再通过工厂对象创建相应的产品对象并使用,最后按顺序释放工厂对象和产品对象的内存,保证内存管理的正确性。

抽象工厂模式

结构及原理

抽象工厂模式的核心在于创建一系列相关的产品对象,其结构特点如下:
抽象工厂(Abstract Factory):定义了创建一系列相关产品的抽象方法,例如创建产品 A、产品 B 等多个抽象方法(在更复杂场景中可能更多)。
具体工厂(Concrete Factory):实现抽象工厂接口,负责创建一组特定的相关产品对象,满足特定的业务需求组合。
抽象产品族(Abstract Product Family):包含多个抽象产品类,这些抽象产品类通常在业务上是相关联的,一起构成了产品族的抽象定义。
具体产品(Concrete Product):实现抽象产品族中的相应抽象产品类,代表具体的产品对象,不同的具体工厂创建不同组合的具体产品。

C++ 代码示例

下面以一个简单的游戏开发中创建不同主题风格的游戏角色和武器为例(比如有魔幻主题和科幻主题):

#include <iostream>
#include <string>// 抽象产品:游戏角色
class Character
{
public:virtual void show() = 0;virtual ~Character() {}
};// 抽象产品:游戏武器
class Weapon
{
public:virtual void attack() = 0;virtual ~Weapon() {}
};// 具体产品:魔幻角色
class MagicCharacter : public Character 
{
public:void show() override{std::cout << "A magic character appears." << std::endl;}
};// 具体产品:魔幻武器
class MagicWeapon : public Weapon
{
public:void attack() override {std::cout << "Magic weapon attacks with spells." << std::endl;}
};// 具体产品:科幻角色
class SciFiCharacter : public Character 
{
public:void show() override{std::cout << "A sci-fi character appears." << std::endl;}
};// 具体产品:科幻武器
class SciFiWeapon : public Weapon
{
public:void attack() override {std::cout << "Sci-fi weapon attacks with energy beams." << std::endl;}
};// 抽象工厂
class AbstractFactory
{
public:virtual Character* createCharacter() = 0;virtual Weapon* createWeapon() = 0;virtual ~AbstractFactory() {}
};// 具体工厂:魔幻主题工厂
class MagicFactory : public AbstractFactory
{
public:Character* createCharacter() override{return new MagicCharacter();}Weapon* createWeapon() override{return new MagicWeapon();}
};// 具体工厂:科幻主题工厂
class SciFiFactory : public AbstractFactory 
{
public:Character* createCharacter() override{return new SciFiCharacter();}Weapon* createWeapon() override {return new SciFiWeapon();}
};int main()
{AbstractFactory* magicFactory = new MagicFactory();AbstractFactory* sciFiFactory = new SciFiFactory();// 创建魔幻主题的角色和武器Character* magicCharacter = magicFactory->createCharacter();Weapon* magicWeapon = magicFactory->createWeapon();// 创建科幻主题的角色和武器Character* sciFiCharacter = sciFiFactory->createCharacter();Weapon* sciFiWeapon = sciFiFactory->createWeapon();if (magicCharacter) {magicCharacter->show();delete magicCharacter;}if (magicWeapon){magicWeapon->attack();delete magicWeapon;}if (sciFiCharacter){sciFiCharacter->show();delete sciFiCharacter;}if (sciFiWeapon){sciFiWeapon->attack();delete sciFiWeapon;}delete magicFactory;delete sciFiFactory;char t;std::cin>>t;return 0;
}

在这个示例中:
Character 和 Weapon 分别是抽象的游戏角色和武器产品类,定义了各自展示和攻击的抽象方法。
MagicCharacter、MagicWeapon、SciFiCharacter、SciFiWeapon 是对应的具体产品类,实现了各自的具体行为逻辑。
AbstractFactory 是抽象工厂类,定义了创建角色和武器的抽象方法。
MagicFactory 和 SciFiFactory 是具体工厂类,分别负责创建魔幻主题和科幻主题的角色和武器这一组相关产品。在 main 函数中,通过不同的具体工厂创建相应主题的产品并调用其方法展示功能,最后正确释放所有创建对象所占用的内存。

总结

简单工厂模式、工厂模式、抽象工厂模式是逐渐递进,
1、简单工厂模式是在一个工厂内生产多个产品;
2、工厂模式是一个工厂生产一个产品;
3、抽象工厂模式是一个工厂生产多个产品。


http://www.ppmy.cn/server/152827.html

相关文章

基于Spring Boot的个性化推荐外卖点餐系统

一、系统概述 该系统旨在为用户提供便捷、个性化的外卖点餐体验&#xff0c;同时为商家提供高效、智能的餐饮管理服务。通过利用Spring Boot框架的稳定性和可扩展性&#xff0c;系统实现了前后端分离的开发模式&#xff0c;支持多种设备和平台&#xff0c;确保用户在不同场景下…

RabbitMQ中的Topic模式

在现代分布式系统中&#xff0c;消息队列&#xff08;Message Queue&#xff09;是实现异步通信、解耦系统组件的重要工具。RabbitMQ 是一个广泛使用的开源消息代理&#xff0c;支持多种消息传递模式&#xff0c;其中 Topic 模式 是一种灵活且强大的模式&#xff0c;允许生产者…

一步一步写线程之十六线程的安全退出之二例程

一、说明 在一篇分析了多线程的安全退出的相关机制和方式&#xff0c;那么本篇就针对前一篇的相关的分析进行举例分析。因为有些方法实现的方法类似&#xff0c;可能就不一一重复列举了&#xff0c;相关的例程主要以在Linux上的运行为主。 二、实例 线程间的同步&#xff0c…

【后端面试总结】MySQL主从复制逻辑的技术介绍

MySQL主从复制逻辑的技术介绍 1. 基本概念 MySQL主从复制是一种数据库复制技术&#xff0c;用于将一个数据库服务器&#xff08;主服务器&#xff0c;Master&#xff09;上的数据更改同步到一个或多个其他数据库服务器&#xff08;从服务器&#xff0c;Slave&#xff09;上。…

open Feign服务抽取

open Feign虽然简化了远程调用&#xff0c;但是仍然存在着一些不太好的问题&#xff0c;这种问题并不是代码程序的问题&#xff0c;而是代码无法服用&#xff0c;无法构成一种编程的思维模式&#xff0c;如果一个服务需要多次被其他服务所引用并且服务数量很多的时候&#xff0…

【Canvas与仪表盘】铝圈蓝底汽车速度仪表盘(可用键盘按键调节速度值)

【速度调节方法】 W或上箭头加速&#xff0c;S或下箭头减速。 【成图】 120*120的png图标 大小图&#xff1a; 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8&quo…

推荐一款免费且好用的 国产 NAS 系统 ——FnOS

一、系统基础信息 开发基础&#xff1a;基于最新的Linux内核&#xff08;Debian发行版&#xff09;深度开发&#xff0c;兼容主流x86硬件&#xff08;ARM还没适配&#xff09;&#xff0c;自由组装NAS&#xff0c;灵活扩展外部存储。 使用情况&#xff1a;官方支持功能较多&am…

阿里云百炼大模型生成贪吃蛇小游戏

阿里云百炼大模型生成贪吃蛇小游戏 为了在贪吃蛇游戏中添加背景音乐&#xff0c;我们可以使用Pygame的mixer模块。以下是修改后的代码&#xff0c;包含了背景音乐的加载和播放功能&#xff1a; 安装Pygame&#xff08;如果你还没有安装&#xff09;&#xff1a; pip install p…