二十三种设计模式(三)--抽象工厂模式

抽象工厂模式

抽象工厂模式在代码上看, 仅仅是将工厂方法模式的具体方法类由一个扩展成了多个,

方法类接口由一个变成一组

但是抽象方法类最终要解决的是"一组相关属性"的问题

具体实现示例如下:

工厂类的接口包含一组方法接口, 这里是和工厂方法模式最直接的区别

所以, 抽象工厂模式解决的问题就是, 一个工厂对象是通过一组相关子对象共同协作完成的.

如图所示, 当工厂类的产品不是单一的类对象构成, 而是需要一组类对象才能构成时, 就需要通过抽象工厂模式实现更大程度的解耦及更大程度的扩展性.

具体实现示例:

java 复制代码
// 工厂类本身可扩展
// 工厂类, 相比较工厂方法类, 此处扩展方法接口为一组方法
public interface Factory {
    PartA getPartA();
    PartB getPartB();
    PartC getPartC();
}

class FactoryA implements Factory {
    public PartA getPartA() {
        return new PartAImplA();
    }

    public PartB getPartB() {
        return new PartBImplA();
    }

    public PartC getPartC() {
        return new PartCImplA();
    }
}

class FactoryB implements Factory {
    public PartA getPartA() {
        return new PartAImplB();
    }

    public PartB getPartB() {
        return new PartBImplB();
    }

    public PartC getPartC() {
        return new PartCImplB();
    }
}

具体的实现类接口A部分:

java 复制代码
public interface PartA {
    void do_part_a();
}

class PartAImplA implements PartA {
    public void do_part_a() {
        System.out.println("Worker finished 1/3 job in Factory A.");
    }
}

class PartAImplB implements PartA {
    public void do_part_a() {
        System.out.println("Worker finished 1/3 job in Factory B");
    }
}

具体的实现类接口B部分:

java 复制代码
public interface PartB {
    void do_part_b();
}

class PartBImplA implements PartB {
    public void do_part_b() {
        System.out.println("Worker finished 2/3 job in Factory A.");
    }
}

class PartBImplB implements PartB {
    public void do_part_b() {
        System.out.println("Worker finished 2/3 job in Factory B.");
    }
}

具体的实现类接口C部分:

java 复制代码
public interface PartC {
    void do_part_c();
}

class PartCImplA implements PartC {
    public void do_part_c() {
        System.out.println("Worker finished 3/3 job in Factory A.");
    }
}

class PartCImplB implements PartC {
    public  void do_part_c() {
        System.out.println("Worker finished 3/3 job in Factory B.");
    }
}

实例化并调用:

java 复制代码
public class AbstractFactory {
    public static void main(String[] args) {
        FactoryA factoryA = new FactoryA();
        PartA workAPartA = factoryA.getPartA();
        PartB workAPartB = factoryA.getPartB();
        PartC workAPartC = factoryA.getPartC();
        workAPartA.do_part_a();
        workAPartB.do_part_b();
        workAPartC.do_part_c();

        FactoryB factoryB = new FactoryB();
        PartA workBPartA = factoryB.getPartA();
        PartB workBPartB = factoryB.getPartB();
        PartC workBPartC = factoryB.getPartC();
        workBPartA.do_part_a();
        workBPartB.do_part_b();
        workBPartC.do_part_c();
    }
}

运行结果:

复制代码
Worker finished 1/3 job in Factory A.
Worker finished 2/3 job in Factory A.
Worker finished 3/3 job in Factory A.
Worker finished 1/3 job in Factory B
Worker finished 2/3 job in Factory B.
Worker finished 3/3 job in Factory B.

抽象工厂模式与工厂方法模式显著的区别如下:

  1. 工厂方法模式中, 一个工厂只生产一个产品, 但抽象工厂模式下, 一个工厂产生一组相关产品
  2. 工厂类接口的一组方法是相类似的, 成套出现的

总结, 抽象方法是多个工厂方法的组合 + 产品族一致性的约束。

相关推荐
皮皮林5517 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河7 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程10 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅12 小时前
Java面向对象入门(类与对象,新手秒懂)
java
静水流深_沧海一粟12 小时前
04 | 别再写几十个参数的构造函数了——建造者模式
设计模式
StarkCoder12 小时前
从UIKit到SwiftUI的迁移感悟:数据驱动的革命
设计模式
初次攀爬者13 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺13 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart14 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot