ABSTRACT FACTORY(抽象工厂) -- 对象创建型模式

本文介绍了抽象工厂模式,用于创建一系列相关对象的接口,通过提供不同具体工厂创建特定产品。它支持系统独立于产品细节,便于扩展和更换产品系列。展示了如何使用抽象工厂、抽象产品和具体实现的实例,以及工厂方法和单例模式的应用。
摘要由CSDN通过智能技术生成

ABSTRACT FACTORY(抽象工厂) – 对象创建型模式

  1. 意图: 提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们的具体类型

  2. 别名:Kit

  3. 动机:考虑一个支持多种视感(look-and-feel)标准的用户界面工具包。

  4. 适用性:

    a. 一个系统要独立于它得产品的创建、组合和表示时。

    b. 一个系统要由多个产品系列中的一个来配置时。

    c. 当你要强调一系列相关产品的对象的设计以便进行联合使用。

    d. 当你提供一个产品类库,而只想显示它们的接口而不是实现时。

  5. 结构:

在这里插入图片描述

  1. 参与者:

    a. AbstractFactory:声明一个创建抽象产品对象的操作接口

    b. ConcreteFactory: 实现创建具体产品对象的操作

    c. AbstractProduct: 为一类产品对象声明一个接口

    d. ConcreteProduct:定义一个将被相应的具体工厂创建的产品对象。实现AbstractProduct接口

    e. Client:仅使用由AbstractFactory和AbstractProduct类声明的接口

  2. 协作:

    通常在运行时刻创建一个ConcreteFactory类的实例。

    这一具体的工厂创建具有特定实现的产品对象。

    为创建不同的产品对象,客户应使用不同的具体工厂。

  3. 效果:

    a. 它分离了具体类

    b. 它使得易于交换产品系列

    c. 它有利于产品的一致性

    d. 难以支持新品种的产品

  4. 实现

    a. 将工厂作为单件

    b. 创建产品

    c. 定义可拓展的工厂

  5. 代码示例:

    
    //抽象工厂
    
    public interface AbstractFactory {
    
        public AbstractProductA CreateProductA();
    
        public AbstractProductB CreateProductB();
    
    }
    
    
    
    //抽象产品A
    
    public interface AbstractProductA {
    
        public void describe();
    
    }
    
    
    
    //抽象产品B
    
    public interface AbstractProductB {
    
        public void describe();
    
    }
    
    
    
    //实现抽象产品A的产品A1
    
    public class ProductA1 implements AbstractProductA {
    
        @Override
    
        public void describe() {
    
            System.out.println("This is ProductA1");
    
        }
    
    }
    
    
    
    //实现抽象产品A的产品A2
    
    public class ProductA2 implements AbstractProductA {
    
        @Override
    
        public void describe() {
    
            System.out.println("This is ProductA2");
    
        }
    
    }
    
    
    
    //实现抽象产品B的产品B1
    
    public class ProductB1 implements AbstractProductB {
    
        @Override
    
        public void describe() {
    
            System.out.println("This is ProductB1");
    
        }
    
    }
    
    
    
    //实现抽象产品B的产品B2
    
    public class ProductB2 implements AbstractProductB {
    
        @Override
    
        public void describe() {
    
            System.out.println("This is ProductB2");
    
        }
    
    }
    
    
    
    //实现抽象工厂的具体工厂1
    
    public class ConcreteFactory1 implements AbstractFactory {
    
    
    
        @Override
    
        public AbstractProductA CreateProductA() {
    
            return new ProductA1();
    
        }
    
    
    
        @Override
    
        public AbstractProductB CreateProductB() {
    
            return new ProductB1();
    
        }
    
    }
    
    
    
    //实现抽象工厂的具体工厂2
    
    public class ConcreteFactory2 implements AbstractFactory {
    
        @Override
    
        public AbstractProductA CreateProductA() {
    
            return new ProductA2();
    
        }
    
    
    
        @Override
    
        public AbstractProductB CreateProductB() {
    
            return new ProductB2();
    
        }
    
    }
    
    
    
    //客户端调用
    
    public class Client {
    
        public static void main(String[] args) {
    
            AbstractFactory factory1 = new ConcreteFactory1();
    
    
    
            AbstractProductA productA1 = factory1.CreateProductA();
    
            AbstractProductB productB1 = factory1.CreateProductB();
    
            productA1.describe();
    
            productB1.describe();
    
        }
    
    }
    
    
  6. 已知应用

  7. 相关模式:

    AbstractFactory类通常用工厂方法(Factory Method)实现,但它们也可以用Prototype实现。

    一个具体的工厂通常是一个单件(Singleton)

  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值