【3W2H设计模式】抽象工厂模式(Abstract Factory Pattern)

简介: 【3W2H设计模式】抽象工厂模式(Abstract Factory Pattern)

【3W2H设计模式】抽象工厂模式(Abstract Factory Pattern)

一、WHAT 什么是抽象工厂模式

抽象工厂模式(Abstract Factory Pattern)是围绕一个超级工厂创建其他工厂,该超级工厂又称为其他工厂的工厂;抽象工厂模式是创建型模式的一种,它提供了一种创建对象的最佳方式。

在抽象工厂模式中,接口是负责创建一个相关对象的工厂,不需要显式指定它们的类。每个生成的工厂都能按照工厂模式提供对象。

二、WHY 为什么用抽象工厂模式

采用工厂方法包括抽象工厂方法都有的一个好处是分离了创建对象的细节,封装了创建产品对象的过程,并且分析了具体的类,在客户端中通过接口进行调用,对产品创建和调用进行了解耦。其次抽象工厂方法是针对与一个产品族,使得易于交换产品系列,只需改变具体的工厂就可以使用不同的产品配置。

当一个产品族中的产品对象被设计成一起工作且一个应用只是用同一族的对象,抽象工厂的接口确定了可以被创建的产品集合。

三、WHEN 什么时候用抽象工厂模式

  1. 抽象工厂模式隔离了具体类的生成,使得客户并不需要知道什么被创建。由于这种隔离,更换一个具体工厂就变得相对容易。所有的具体工厂都实现了抽象工厂中定义的那些公共接口,因此只需改变具体工厂的实例,就可以在某种程度上改变整个软件系统的行为。另外,应用抽象工厂模式可以实现高内聚低耦合的设计目的,因此抽象工厂模式得到了广泛的应用。
  2. 增加新的具体工厂和产品族很方便,因为一个具体的工厂实现代表的是一个产品族,无须修改已有系统,符合“开闭原则”。
  3. 抽象工厂模式主要在于应对“新系列”的需求变化。分离了具体的类,抽象工厂模式帮助你控制一个应用创建的对象的类,因为一个工厂封装创建产品对象的责任和过程。它将客户和类的实现分离,客户通过他们的抽象接口操纵实例,产品的类名也在具体工厂的实现中被分离,它们不出现在客户代码中。它使得易于交换产品系列。一个具体工厂类在一个应用中仅出现一次——即在它初始化的时候。这使得改变一个应用的具体工厂变得很容易。它只需改变具体的工厂即可使用不同的产品配置,这是因为一个抽象工厂创建了一个完整的产品系列,所以整个产品系列会立刻改变。它有利于产品的一致性。当一个系列的产品对象被设计成一起工作时,一个应用一次只能使用同一个系列中的对象,这一点很重要,而抽象工厂很容易实现这一点。抽象工厂模式有助于这样的团队的分工,降低了模块间的耦合性,提高了团队开发效率。

四、HOW 如何实现抽象工厂模式

4.1 抽象工厂类图

4.2 抽象工厂组成及作用

编号 组成(角色) 关系 作用
1 抽象产品族(AbstractProduct) 抽象产品的父类 描述抽象产品的公共接口
2 抽象产品(Product) 具体产品的父类 描述具体产品的公共接口
3 具体产品(Concrete Product) 抽象产品的子类;工厂类创建的目标类 描述生产的具体产品
4 抽象工厂(Creator) 具体工厂的父类 描述具体工厂的公共接口
5 具体工厂(Concrete Creator) 抽象工厂的子类;被外界调用 描述具体工厂;实现FactoryMethod工厂方法创建产品的实例

4.3 抽象工厂实现的步骤

步骤1: 创建抽象产品族类 ,定义抽象产品的公共接口;

步骤2: 创建具体产品类(继承抽象产品类) & 定义生产的具体产品;

步骤3: 创建抽象工厂类,定义具体工厂的公共接口;

步骤4:创建具体工厂类(继承抽象工厂类),定义创建对应具体产品实例的方法;

**步骤5:**客户端通过实例化具体的工厂类,并调用其创建不同目标产品的方法创建不同具体产品类的实例

4.4 抽象工厂实例

步骤一:创建抽象产品族
/**
 * 创建抽象产品族A
 */
public abstract class ProductAAbstract {
    public void createToLine(String lineName) {
        System.out.println("This is ProductAAbstract Line");
    }
}
/**
* 创建抽象产品族 ProductB
*/
public abstract class ProdutBAbstract {
    public void ProductionLine(String lineName) {
        System.out.println("This is ProductBAbstract LineName");
    }
}
步骤二: 实现抽象产品族并创建具体产品
/**
 * 创建具体产品ProductA
 */
public class ConcreteProductA extends ProductAAbstract {
    @Override
    public void createToLine(String lineName) {
        System.out.println("ConcreteProductA-"+lineName);
    }
}
/**
 * 创建具体产品ProductAA
 */
public class ConcreteProductAA extends ConcreteProductA{
    @Override
    public void createToLine(String lineName) {
        System.out.println("ConcreteProductAA-"+lineName);
    }
}
/**
 * 继承ProdutBAbstract,创建具体产品ConcreteProductB
 */
public class ConcreteProductB extends ProdutBAbstract {
    @Override
    public void ProductionLine(String lineName) {
        System.out.println("ConcreteProductB-"+lineName);
    }
}
/**
 * 实现ConcreteProductB,创建产品ConcreteProductBB
 */
public class ConcreteProductBB extends ConcreteProductB{
    @Override
    public void ProductionLine(String lineName) {
        System.out.println("ConcreteProductBB-"+lineName);
    }
}
步骤三: 创建抽象工厂
/**
 * 创建抽象工厂
 */
public interface AbstractFactory {
    ProductAAbstract CreateAProductManage();
    ProdutBAbstract  CreateBProductManage();
}
步骤四:实现抽象工厂,并创建实例工厂
/**
 * 创建抽象工厂,并创建实例工厂ContreteFactoryA
 */
public class ContreteFactoryA implements AbstractFactory {
    @Override
    public ProductAAbstract CreateAProductManage() {
        return new ConcreteProductA();
    }
    @Override
    public ProdutBAbstract CreateBProductManage() {
        return new ConcreteProductB();
    }
}
/**
 * 创建抽象工厂,并创建实例工厂ContreteFactoryB
 */
public class ContreteFactoryB implements AbstractFactory {
    @Override
    public ProductAAbstract CreateAProductManage() {
        return new ConcreteProductAA();
    }
    @Override
    public ProdutBAbstract CreateBProductManage() {
        return new ConcreteProductBB();
    }
}
步骤五:客户端通过实例化具体的工厂类
/**
 * 客户端通过实例化具体的工厂类
 */
public class Client {
    public static void main(String[] args) {
        Client client=new Client();
        AbstractFactory factory= client.getFactory("A");
        factory.CreateAProductManage().createToLine("LineName Factory");
        factory.CreateBProductManage().ProductionLine("LineName Factory");
    }
    public AbstractFactory getFactory(String FactoryName) {
        if ("A".equals(FactoryName)) {
            return new ContreteFactoryA();
        } else if ("B".equals(FactoryName)) {
            return new ContreteFactoryB();
        }else{
            return  null;
        }
    }
}

五、HOW TO CHANGE(抽象工厂模式在代码中如何使用)

抽象工厂模式适用场景

  • 忽略创建细节: 客户端不关心产品实例如何被创建 , 实现等细节;
  • 创建产品族: 强调一系列相关的产品对象 , 一般是同一个产品族 , 一起使用 创建对象需要大量重复的代码 ;
  • 产品类库: 提供一个产品类 的库 , 所有的产品 以 同样的接口出现 , 使 客户端不依赖于具体实现 ;


目录
相关文章
|
3月前
|
设计模式
设计模式-工厂模式 Factory Pattern(简单工厂、工厂方法、抽象工厂)
这篇文章详细解释了工厂模式,包括简单工厂、工厂方法和抽象工厂三种类型。每种模式都通过代码示例展示了其应用场景和实现方法,并比较了它们之间的差异。简单工厂模式通过一个工厂类来创建各种产品;工厂方法模式通过定义一个创建对象的接口,由子类决定实例化哪个类;抽象工厂模式提供一个创建相关或依赖对象家族的接口,而不需要明确指定具体类。
设计模式-工厂模式 Factory Pattern(简单工厂、工厂方法、抽象工厂)
|
3月前
|
设计模式 Java
设计模式--适配器模式 Adapter Pattern
这篇文章介绍了适配器模式,包括其基本介绍、工作原理以及类适配器模式、对象适配器模式和接口适配器模式三种实现方式。
|
6月前
|
设计模式
设计模式-05建造者模式(Builder Pattern)
设计模式-05建造者模式(Builder Pattern)
|
7月前
|
设计模式 安全 Java
【设计模式】JAVA Design Patterns——Curiously Recurring Template Pattern(奇异递归模板模式)
该文介绍了一种C++的编程技巧——奇异递归模板模式(CRTP),旨在让派生组件能继承基本组件的特定功能。通过示例展示了如何创建一个`Fighter`接口和`MmaFighter`类,其中`MmaFighter`及其子类如`MmaBantamweightFighter`和`MmaHeavyweightFighter`强制类型安全,确保相同重量级的拳手之间才能进行比赛。这种设计避免了不同重量级拳手间的错误匹配,编译时会报错。CRTP适用于处理类型冲突、参数化类方法和限制方法只对相同类型实例生效的情况。
|
1月前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
|
3月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提升代码的可维护性与扩展性在软件开发过程中,设计模式是开发者们经常用到的工具之一。它们提供了经过验证的解决方案,可以帮助我们解决常见的软件设计问题。本文将介绍PHP中常用的设计模式,以及如何利用这些模式来提高代码的可维护性和扩展性。我们将从基础的设计模式入手,逐步深入到更复杂的应用场景。通过实际案例分析,读者可以更好地理解如何在PHP开发中应用这些设计模式,从而写出更加高效、灵活和易于维护的代码。
本文探讨了PHP中常用的设计模式及其在实际项目中的应用。内容涵盖设计模式的基本概念、分类和具体使用场景,重点介绍了单例模式、工厂模式和观察者模式等常见模式。通过具体的代码示例,展示了如何在PHP项目中有效利用设计模式来提升代码的可维护性和扩展性。文章还讨论了设计模式的选择原则和注意事项,帮助开发者在不同情境下做出最佳决策。
|
1月前
|
设计模式 开发者 Python
Python编程中的设计模式:工厂方法模式###
本文深入浅出地探讨了Python编程中的一种重要设计模式——工厂方法模式。通过具体案例和代码示例,我们将了解工厂方法模式的定义、应用场景、实现步骤以及其优势与潜在缺点。无论你是Python新手还是有经验的开发者,都能从本文中获得关于如何在实际项目中有效应用工厂方法模式的启发。 ###
|
1月前
|
设计模式 安全 Java
Kotlin - 改良设计模式 - 构建者模式
Kotlin - 改良设计模式 - 构建者模式
|
1月前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
42 1
|
2月前
|
设计模式 Java Kotlin
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
本教程详细讲解Kotlin语法,适合希望深入了解Kotlin的开发者。对于快速学习Kotlin语法,推荐查看“简洁”系列教程。本文重点介绍了构建者模式在Kotlin中的应用与改良,包括如何使用具名可选参数简化复杂对象的创建过程,以及如何在初始化代码块中对参数进行约束和校验。
32 3