抽象工厂模式(Abstract factory pattern)- python实现

抽象工厂模式的通俗示例

想象一下,你正在经营一家家具店,你需要从不同的供应商那里采购不同的家具系列。有的供应商提供的是现代风格家具,包括现代沙发、现代椅子和现代桌子;而有的供应商提供的是古典风格家具,包括古典沙发、古典椅子和古典桌子。你不想每次都具体指定要采购哪个供应商的哪个具体产品,你只需要告诉你的采购团队你要的是现代风格家具系列或古典风格家具系列。这里的"现代风格家具系列"和"古典风格家具系列"就可以看作是抽象工厂模式中的"对象家族"。

抽象工厂模式的通俗解释

抽象工厂模式是一种设计模式,它提供了一个抽象的接口,让你可以创建一系列相关或相互依赖的对象,而不需要知道这些对象的具体类。在这个模式中,你只需要知道你想要的对象家族(比如现代或古典家具),而具体的对象创建工作则由具体的工厂来完成。

抽象工厂模式的具体说明

  • 抽象工厂(Abstract Factory):这是一个接口,声明了一组用于创建不同抽象产品的方法。在上述例子中,这个接口可以声明创建沙发、椅子和桌子的方法。

  • 具体工厂(Concrete Factory):实现了抽象工厂接口的类,负责创建具体的产品。比如,一个具体工厂可以是"现代家具工厂",它负责创建现代沙发、现代椅子等;另一个具体工厂可以是"古典家具工厂",它负责创建古典沙发、古典椅子等。

  • 抽象产品(Abstract Product):这些是一组相关产品的抽象类或接口,每类产品都可能有很多不同的具体实现。在例子中,沙发、椅子和桌子就是抽象产品。

  • 具体产品(Concrete Product):实现了抽象产品接口的具体类。比如,现代沙发、现代椅子是具体产品。

抽象工厂模式的优点是:

  • 分离接口与实现:客户端只需知道它们需要什么样的产品家族,而不必知道具体产品的类。

  • 提高可扩展性:新增产品族时,不需要修改已有系统,只需添加一个新的具体工厂即可。

  • 一致的对象创建:确保创建的对象属于同一风格或主题。

但抽象工厂模式也有缺点:

  • 复杂性增加:理解和实现抽象工厂模式需要更多的时间和精力。

  • 扩展困难:如果需要添加新的产品,可能需要修改抽象工厂和所有具体工厂。

在实际应用中,抽象工厂模式特别适合于那些有多种产品族,且产品族中的产品需要一起使用的情况。

python实践

python 复制代码
import abc

# 两种小汽车
class Mercedes_C63(object):
    """梅赛德斯 C63
    """
    def __repr__(self):
        return "Mercedes-Benz: C63"

class BMW_M3(object):
    """宝马 M3
    """
    def __repr__(self):
        return "BMW: M3"

# 两种SUV
class Mercedes_G63(object):
    """梅赛德斯 G63
    """
    def __repr__(self):
        return "Mercedes-Benz: G63"

class BMW_X5(object):
    """宝马 X5
    """
    def __repr__(self):
        return "BMW: X5"

class AbstractFactory(object):
    """抽象工厂类

    该类是一个抽象类,定义了生产不同类型车辆产品的接口除了能生产小汽车外,还可以生产SUV
    使用该模式可以将创建不同类型对象的逻辑进行封装,便于扩展和替换具体实现
    """
    # 标记该类为抽象类
    __metaclass__ = abc.ABCMeta

    # 定义生产小汽车产品的抽象方法
    # 该方法没有具体实现,需要由具体的子类根据实际需求实现
    @abc.abstractmethod
    def product_car(self):
        pass

    # 定义生产SUV产品的抽象方法
    # 同样,该方法的具体实现由具体的子类完成
    @abc.abstractmethod
    def product_suv(self):
        pass

class MercedesFactory(AbstractFactory):
    """梅赛德斯工厂
    """
    def product_car(self):
        return Mercedes_C63()

    def product_suv(self):
        return Mercedes_G63()

class BMWFactory(AbstractFactory):
    """宝马工厂
    """
    def product_car(self):
        return BMW_M3()

    def product_suv(self):
        return BMW_X5()


if __name__ == '__main__':
    c1 = MercedesFactory().product_car()
    s1 = MercedesFactory().product_suv()
    print(c1, s1)
    s2 = BMWFactory().product_suv()
    c2 = BMWFactory().product_car()
    print(c2, s2)
相关推荐
S-X-S1 分钟前
集成Sleuth实现链路追踪
java·开发语言·链路追踪
快乐就好ya9 分钟前
xxl-job分布式定时任务
java·分布式·spring cloud·springboot
沉默的煎蛋16 分钟前
MyBatis 注解开发详解
java·数据库·mysql·算法·mybatis
Aqua Cheng.17 分钟前
MarsCode青训营打卡Day10(2025年1月23日)|稀土掘金-147.寻找独一无二的糖葫芦串、119.游戏队友搜索
java·数据结构·算法
北 染 星 辰23 分钟前
Python网络自动化运维---用户交互模块
开发语言·python·自动化
codists27 分钟前
《CPython Internals》阅读笔记:p336-p352
python
石明亮(JT)33 分钟前
docker部署jenkins
java·docker·jenkins
翻晒时光1 小时前
Java 多线程与并发:春招面试核心知识
java·jvm·面试
小张认为的测试1 小时前
Jenkins邮件通知的详细配置含邮件通知模板!
java·servlet·ci/cd·jenkins·邮件通知
灯火不休ᝰ1 小时前
[java] java基础-字符串篇
java·开发语言·string