【设计模式】抽象工厂模式

简介: 设计模式抽象工厂模式抽象工厂模式(Abstract Factory Pattern)是所有形态的工厂模式中最为抽象和最具一般性的一种形态。
img_a2c517c88581d62612a25018678f05fd.png
设计模式

抽象工厂模式

抽象工厂模式(Abstract Factory Pattern)是所有形态的工厂模式中最为抽象和最具一般性的一种形态。抽象工厂模式是指当有多个抽象角色时,使用的一种工厂模式。抽象工厂模式可以向客户端提供一个接口,使客户端在不必指定产品的具体的情况下,创建多个产品族中的产品对象。

UML类图

img_b891bd3bbbe88fffb527a37662c2bce1.jpe
抽象工厂模式

抽象产品类(AbstractProductX):多个系列抽象产品(X=A,B,C...)。
具体产品类(ProductX):实现基类中的抽象方法(多个不同的具体产品,X=1,2,3..)。
抽象工厂类或接口(AbstractFactory):定义具体工厂的多个公共接口(拥有各系列产品创建的接口)。
具体工厂类(FactoryX):定义创建各系列具体产品实例的方法。(每个工厂对应一种具体产品,X=1,2,3...)。

与工厂模式的区别

  1. 工厂模式的工厂只能生产一个系列的产品。而抽象工厂模式的工厂可以生产一个或多个系列的产品。
  2. 工厂模式关注的是一个系列的不同种产品。而抽象工厂模式关注的是不同系列产品。

案例分析

接着上篇【设计模式】工厂模式的话题。

场景:玩《英雄联盟》(5v5 moba端游)新开一局游戏,游戏开始每个玩家需要选一个英雄之外,还需要选择天赋,召唤师技能。也就是需要创建三种产品。并且,在不同玩法下,比如召唤师峡谷(自选或排位等)与哭嚎深渊(大乱斗),创建的产品也略微有所差异,比如大乱斗下英雄一开始就3级,召唤师技能没有传送,有雪球。结构上:

  1. 产品(三个系列):英雄,天赋,召唤师技能。
  2. 工厂(两个):召唤师峡谷工厂,哭嚎深渊工厂。

代码实现

英雄基类(新增lv成员变量和print()方法)

public abstract class Hero {
    protected String name;
    protected int lv;

    public abstract void say();

    public void print() {
        System.out.println("name:" + name);
        System.out.println("lv:" + lv);
    }

}

只考虑一种英雄,比如寒冰射手-艾希。


img_671ab80140664f0ec744d1e867c908f1.png
艾希

艾希类:

public class Ashe extends Hero {
    // 简化构造方法,只弄个名字。
    public Ashe() {
        this.name = "寒冰射手-艾希";
    }

    // 艾希台词(不重要)
    @Override
    public void say() {
        System.out.println(name + ":" + "世间万物皆系于一箭之上。");
    }
}

召唤师峡谷中的艾希:

public class Ashe_XiaGu extends Ashe {
    // 在召唤师峡谷中初始等级1级。
    public Ashe_XiaGu() {
        super();
        this.lv = 1;
    }
}

哭嚎深渊中的艾希:

public class Ashe_ShenYuan extends Ashe {
    // 在哭嚎深渊中初始等级3级。
    public Ashe_ShenYuan() {
        super();
        this.lv = 3;
    }
}

天赋基类:(就简单点只用打印信息区分下好了)

public abstract class Talent {
    // 只打印一下信息
    public abstract void print();
}

两个天赋实现类:

public class Talent_XiaGu extends Talent{

    @Override
    public void print() {
        System.out.println("召唤师峡谷中的天赋");
    }

}
public class Talent_ShenYuan extends Talent{

    @Override
    public void print() {
        System.out.println("哭嚎深渊中的天赋");
    }

}

召唤师技能基类:

public abstract class Skill {
    // 召唤师技能种类
    protected String[] skill_type;

    // 选择两种召唤师技能
    public void choose(int i, int j) {
        System.out.println("你选择了" + skill_type[i] + "和" + skill_type[j]);
    }
}

两个召唤师技能实现类:

public class Skill_XiaGu extends Skill {
    public Skill_XiaGu() {
        this.skill_type = new String[] { "闪现", "治疗", "传送", "净化", "光盾", "虛弱",
                "惩戒", "疾走" };
    }
}
public class Skill_ShenYuan extends Skill {
    public Skill_ShenYuan() {
        this.skill_type = new String[] { "闪现", "治疗", "雪球", "净化", "光盾", "虛弱",
                "回蓝", "疾走" };
    }
}

准备工作完毕,接下来就是重点了。

抽象工厂类或接口:

public interface AbstractFactory {
    //创建英雄
    public abstract Hero createHero();
    //创建天赋
    public abstract Talent createTalent();
    //创建召唤师技能
    public abstract Skill createSkill();

}

召唤师峡谷工厂类:

public class Factory_XiaGu implements AbstractFactory {
    //假设我选艾希
    public Hero createHero() {
        return new Ashe_XiaGu();
    }

    public Talent createTalent() {
        return new Talent_XiaGu();
    }

    public Skill createSkill() {
        return new Skill_XiaGu();
    }
}

哭嚎深渊工厂类:

public class Factory_ShenYuan implements AbstractFactory {
    //假设我选艾希
    public Hero createHero() {
        return new Ashe_ShenYuan();
    }

    public Talent createTalent() {
        return new Talent_ShenYuan();
    }

    public Skill createSkill() {
        return new Skill_ShenYuan();
    }
}

最后是客户端代码:

public class Client {
    public static void main(String[] args) {
        System.out.println("请选择游戏模式");
        System.out.println("1,召唤师峡谷   2,哭嚎深渊");
        Scanner can = new Scanner(System.in);
        int w = can.nextInt();
        can.close();
        AbstractFactory factory = null;
        switch (w) {
        case 1:
            // 召唤师峡谷
            factory = new Factory_XiaGu();
            break;
        case 2:
            // 哭嚎深渊
            factory = new Factory_ShenYuan();
            break;
        }
        // 英雄(选择的是艾希)
        Hero hero = factory.createHero();
        hero.print();
        hero.say();
        // 天赋
        Talent talent = factory.createTalent();
        talent.print();
        // 召唤师技能
        Skill skill = factory.createSkill();
        skill.choose(0, 2);

    }

}

客户端选择游戏模式,就相当于选择了不同的工厂去生产游戏元素(英雄,天赋,召唤师技能)。

也可以结合工厂模式使用,比如选择游戏类型后,利用工厂模式选择英雄等等。

工厂模式,客户端不需要知道产品的创建过程。并且,客户端只需要选择游戏模式,就可以用工厂创建多个系列的产品(英雄,天赋,召唤师技能)。主要特点就是一个工厂多系列产品。

运行结果

玩局匹配,选召唤师峡谷:


img_7105be0d2819f7ec51b7411142c21fc2.png
控制台

源计划皮肤的寒冰射手。


img_c3dfb710cd45bd77a4d5eed26a21ec65.png
源计划-艾希

实际应用

常见的案例就是使用不同的数据库,数据库能处理用户,也能处理关系。但是,数据库分MySQL,Orical等。处理同样或类似的事情,他们的具体实现存在差异。那就可以抽出一个工厂基类,再分别写两个不同的工厂去处理。这样的话,某些东西就可以做到可迁移的目的。

附件

设计模式Demo
GitHub源码:https://github.com/wzmyyj/Design-Pattern

目录
相关文章
|
5月前
|
设计模式 PHP
php设计模式--抽象工厂模式(二)
php设计模式--抽象工厂模式(二)
29 0
|
4月前
|
设计模式
**工厂模式与抽象工厂模式**都是创建型设计模式,用于封装对象创建,减少耦合
【6月更文挑战第23天】**工厂模式与抽象工厂模式**都是创建型设计模式,用于封装对象创建,减少耦合。工厂模式专注于单个对象,通过具体工厂创建具体产品,适用于简单对象创建;抽象工厂则关注一系列相关产品,提供创建一族对象的接口,适用于处理多个不兼容产品族。选择模式基于问题域的复杂性,单个产品需求时用工厂模式,多产品族时用抽象工厂模式。
29 5
|
10天前
|
设计模式 Java
Java设计模式-抽象工厂模式(5)
Java设计模式-抽象工厂模式(5)
|
5月前
|
设计模式 Java
【设计模式】JAVA Design Patterns——Abstract Factory(抽象工厂模式)
【设计模式】JAVA Design Patterns——Abstract Factory(抽象工厂模式)
|
5月前
|
设计模式 Java
Java一分钟之-设计模式:工厂模式与抽象工厂模式
【5月更文挑战第17天】本文探讨了软件工程中的两种创建型设计模式——工厂模式和抽象工厂模式。工厂模式提供了一个创建对象的接口,延迟实例化到子类决定。过度使用或违反单一职责原则可能导致问题。代码示例展示了如何创建形状的工厂。抽象工厂模式则用于创建一系列相关对象,而不指定具体类,但添加新产品可能需修改现有工厂。代码示例展示了创建颜色和形状的工厂。根据需求选择模式,注意灵活性和耦合度。理解并恰当运用这些模式能提升代码质量。
56 2
|
5月前
|
设计模式 Java
【设计模式系列笔记】抽象工厂模式
抽象工厂模式(Abstract Factory Pattern)是一种设计模式,属于创建型模式之一。它提供了一种方式来创建一系列相关或相互依赖的对象,而无需指定它们具体的类。抽象工厂模式通过引入抽象的工厂接口,使得客户端代码可以使用抽象的接口来创建一组相关的产品,而不关心这些产品的具体实现。
172 4
|
2月前
|
设计模式 Java
Java 设计模式之谜:工厂模式与抽象工厂模式究竟隐藏着怎样的神奇力量?
【8月更文挑战第30天】在Java编程中,设计模式为常见问题提供了高效解决方案。工厂模式与抽象工厂模式是常用的对象创建型设计模式,能显著提升代码的灵活性、可维护性和可扩展性。工厂模式通过定义创建对象的接口让子类决定实例化哪个类;而抽象工厂模式则进一步提供了一个创建一系列相关或相互依赖对象的接口,无需指定具体类。这种方式使得系统更易于扩展和维护。
32 1
|
2月前
|
设计模式 XML 存储
【三】设计模式~~~创建型模式~~~抽象工厂模式(Java)
文章详细介绍了抽象工厂模式,这是一种创建型设计模式,用于提供一个接口以创建一系列相关或相互依赖的对象,而不指定它们具体的类。通过代码示例和结构图,文章展示了抽象工厂模式的动机、定义、结构、优点、缺点以及适用场景,并探讨了如何通过配置文件和反射机制实现工厂的动态创建。
【三】设计模式~~~创建型模式~~~抽象工厂模式(Java)
|
2月前
|
设计模式 Java C语言
设计模式-----------工厂模式之抽象工厂模式(创建型)
抽象工厂模式是一种创建型设计模式,它提供了一个接口用于创建一系列相关或相互依赖的对象,而无需指定具体类,从而增强了程序的可扩展性并确保客户端只使用同一产品族的产品。
设计模式-----------工厂模式之抽象工厂模式(创建型)
|
2月前
|
设计模式 存储 XML
[设计模式]创建型模式-抽象工厂模式
[设计模式]创建型模式-抽象工厂模式