【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(抽象工厂模式在代码中如何使用)

抽象工厂模式适用场景

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


目录
相关文章
|
5月前
|
设计模式 Java 关系型数据库
【设计模式】【创建型模式】抽象工厂模式(Abstract Factory)
一、入门 什么是抽象工厂模式? 抽象工厂模式是一种创建型设计模式,它提供了一个接口,用于创建相关或依赖对象的家族,而不需要指定具体的类。 简单来说,抽象工厂模式是工厂方法模式的升级版,它能够创建一组相
164 14
|
7月前
|
设计模式 Java 数据安全/隐私保护
Java 设计模式:装饰者模式(Decorator Pattern)
装饰者模式属于结构型设计模式,允许通过动态包装对象的方式为对象添加新功能,提供比继承更灵活的扩展方式。该模式通过组合替代继承,遵循开闭原则(对扩展开放,对修改关闭)。
设计模式-工厂模式 Factory Pattern(简单工厂、工厂方法、抽象工厂)
这篇文章详细解释了工厂模式,包括简单工厂、工厂方法和抽象工厂三种类型。每种模式都通过代码示例展示了其应用场景和实现方法,并比较了它们之间的差异。简单工厂模式通过一个工厂类来创建各种产品;工厂方法模式通过定义一个创建对象的接口,由子类决定实例化哪个类;抽象工厂模式提供一个创建相关或依赖对象家族的接口,而不需要明确指定具体类。
设计模式-工厂模式 Factory Pattern(简单工厂、工厂方法、抽象工厂)
|
设计模式 Java
设计模式--适配器模式 Adapter Pattern
这篇文章介绍了适配器模式,包括其基本介绍、工作原理以及类适配器模式、对象适配器模式和接口适配器模式三种实现方式。
|
5月前
|
设计模式 Java 数据库连接
【设计模式】【创建型模式】工厂方法模式(Factory Methods)
一、入门 什么是工厂方法模式? 工厂方法模式(Factory Method Pattern)是一种创建型设计模式,它定义了一个用于创建对象的接口,但由子类决定实例化哪个类。工厂方法模式使类的实例化延迟
135 16
|
5月前
|
设计模式 负载均衡 监控
并发设计模式实战系列(2):领导者/追随者模式
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发设计模式实战系列,第二章领导者/追随者(Leader/Followers)模式,废话不多说直接开始~
131 0
|
5月前
|
设计模式 监控 Java
并发设计模式实战系列(1):半同步/半异步模式
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发设计模式实战系列,第一章半同步/半异步(Half-Sync/Half-Async)模式,废话不多说直接开始~
124 0
|
5月前
|
设计模式 安全 Java
并发设计模式实战系列(12):不变模式(Immutable Object)
🌟 大家好,我是摘星!🌟今天为大家带来的是并发设计模式实战系列,第十二章,废话不多说直接开始~
100 0
|
5月前
|
设计模式 算法 Java
设计模式觉醒系列(04)策略模式|简单工厂模式的升级版
本文介绍了简单工厂模式与策略模式的概念及其融合实践。简单工厂模式用于对象创建,通过隐藏实现细节简化代码;策略模式关注行为封装与切换,支持动态替换算法,增强灵活性。两者结合形成“策略工厂”,既简化对象创建又保持低耦合。文章通过支付案例演示了模式的应用,并强调实际开发中应根据需求选择合适的设计模式,避免生搬硬套。最后推荐了JVM调优、并发编程等技术专题,助力开发者提升技能。
|
10月前
|
设计模式 前端开发 搜索推荐
前端必须掌握的设计模式——模板模式
模板模式(Template Pattern)是一种行为型设计模式,父类定义固定流程和步骤顺序,子类通过继承并重写特定方法实现具体步骤。适用于具有固定结构或流程的场景,如组装汽车、包装礼物等。举例来说,公司年会节目征集时,蜘蛛侠定义了歌曲的四个步骤:前奏、主歌、副歌、结尾。金刚狼和绿巨人根据此模板设计各自的表演内容。通过抽象类定义通用逻辑,子类实现个性化行为,从而减少重复代码。模板模式还支持钩子方法,允许跳过某些步骤,增加灵活性。
486 11