抽象工厂模式

1. 什么是抽象工厂模式

抽象工厂模式是所有形态的工厂模式中最为抽象和最其一般性的。抽象工厂模式可以向客户端提供一个接口,使得客户端在不必指定产品的具体类型的情况下,能够创建多个产品族的产品对象。

03_抽象工厂模式 - 图1

2. 模式中包含的角色及其职责

  1. 抽象工厂(Creator)角色:工厂模式的核心,包含对多个产品结构的声明,任何工厂类都必须实现这个。
  2. 具体工厂(Concrete creator)角色:具体工厂类是抽象工厂的一个实现,负责实例化某个产品族中的产品对象。
  3. 抽象(Product)角色:抽象模式所创建的所有对象的父类,它负责描述所有实例所共有的公共接口。
  4. 具体产品(Concrete product)角色:抽象模式所创建的具体实例对象。

总结:抽象工厂中方法对应产品结构,具体工厂对应产品族。

3. 代码演示

3.1. 产品等级结构

  1. public interface Fruit {
  2. void get();
  3. }
  1. public abstract class Apple implements Fruit {
  2. @Override
  3. public abstract void get();
  4. }
  1. public abstract class Banana implements Fruit {
  2. @Override
  3. public abstract void get();
  4. }

3.2. 具体产品

  1. public class NorthApple extends Apple {
  2. @Override
  3. public void get() {
  4. System.out.println("采集北方苹果");
  5. }
  6. }
  1. public class SouthApple extends Apple {
  2. @Override
  3. public void get() {
  4. System.out.println("采集南方苹果");
  5. }
  6. }
  1. public class NorthBanana extends Banana {
  2. @Override
  3. public void get() {
  4. System.out.println("采集北方香蕉");
  5. }
  6. }
  1. public class SouthBanana extends Banana {
  2. @Override
  3. public void get() {
  4. System.out.println("采集南方香蕉");
  5. }
  6. }

3.3. 抽象工厂

  1. public interface FruitFactory {
  2. Fruit getApple();
  3. Fruit getBanana();
  4. }

3.4. 具体工厂

  1. public class NorthFruitFactory implements FruitFactory {
  2. @Override
  3. public Fruit getApple() {
  4. return new NorthApple();
  5. }
  6. @Override
  7. public Fruit getBanana() {
  8. return new NorthBanana();
  9. }
  10. }
  1. public class SouthFruitFactory implements FruitFactory {
  2. @Override
  3. public Fruit getApple() {
  4. return new SouthBanana();
  5. }
  6. @Override
  7. public Fruit getBanana() {
  8. return new SouthBanana();
  9. }
  10. }
  1. FruitFactory northFruitFactory = new NorthFruitFactory();
  2. Fruit apple1 = northFruitFactory.getApple();
  3. apple1.get();
  4. Fruit banana1 = northFruitFactory.getBanana();
  5. banana1.get();
  6. FruitFactory southFruitFactory = new SouthFruitFactory();
  7. Fruit apple2 = southFruitFactory.getApple();
  8. apple2.get();
  9. Fruit banana2 = southFruitFactory.getBanana();
  10. banana2.get();

3.5. 新增产品族

  1. public class WenshiApple extends Apple {
  2. @Override
  3. public void get() {
  4. System.out.println("采集温室苹果");
  5. }
  6. }
  1. public class WenshiBanana extends Banana {
  2. @Override
  3. public void get() {
  4. System.out.println("采集温室香蕉");
  5. }
  6. }
  1. public class WenshiFruitFactory implements FruitFactory {
  2. @Override
  3. public Fruit getApple() {
  4. return new WenshiApple();
  5. }
  6. @Override
  7. public Fruit getBanana() {
  8. return new WenshiBanana();
  9. }
  10. }
  1. FruitFactory wenshiFruitFactory = new WenshiFruitFactory();
  2. Fruit apple3 = wenshiFruitFactory.getApple();
  3. apple3.get();
  4. Fruit banana3 = wenshiFruitFactory.getBanana();
  5. banana3.get();

3.6. 新增产品等级

比较麻烦,要修改抽象工厂和具体工厂。

水果工厂 \ 水果 苹果 香蕉
北方水果工厂 北方苹果 北方香蕉
南方水果工厂 南方苹果 南方香蕉
温室水果工厂 温室苹果 温室香蕉
  • 纵向一列表示一个产品等级
  • 横向一排表示一个产品族
  • 一个产品族对应一个具体工厂
  • 新增产品族

    • 新增不同产品等级的具体产品
    • 新增产品族的具体工厂
  • 新增产品等级

    • 修改抽象工厂的定义
    • 修改已存在的具体工厂的定义