抽象工厂模式其实和工厂方法模式差不多,我们需要了解的就是抽象工厂模式是通过抽象工厂类(AbstarctFactory)来增加具体不能种类的产品接口实现,并且子类实现父类方法进行具体的产品生产;不同产品也会有不同产品的抽象产品类和具体产品类。
模式的结构与实现
和工厂方法模式一样,抽象工厂模式的主要角色如下。
- 抽象工厂(AbstractFactory):提供了创建产品的接口,它包含多个创建产品的方法 newProduct(),可以创建多个不同等级的产品。
- 具体工厂(ConcreteFactory):主要是实现抽象工厂中的多个抽象方法,完成具体产品的创建。
- 抽象产品(AbstractProduct):定义了产品的规范,描述了产品的主要特性和功能,抽象工厂模式有多个抽象产品。
- 具体产品(Product):实现了抽象产品角色所定义的接口,由具体工厂来创建,它同具体工厂之间是多对一的关系。
具体UML类图如下:
下面我们继续用手机生产来讲解该模式,不过我们添加了新的产品PC类:
这里接着引用上一篇简单工厂模式文章里的抽象产品Phone类、具体产品PgPhone类和XmPhone类,并且添加抽象产品Pc类、具体产品PgPc类和XmPc类,以及需要的具体工厂PcFactory类。需要改造的就是抽象工厂类和具体工厂类。
抽象产品PC类:
public interface Pc {
void make();
}
具体产品PgPc类和XmPc类:
public class PgPc implements Pc{
public PgPc(){
this.make();
}
@Override
public void make() {
System.out.println("制造苹果电脑!");
}
}
public class XmPC implements Pc{
public XmPC(){
this.make();
}
@Override
public void make() {
System.out.println("制造小米电脑!");
}
}
抽象工厂类(有多个产品的实现方法):
public interface AbstractFactory {
Phone makePhone();
Pc makePc();
}
具体工厂类:
public class PgFactory implements AbstractFactory{
@Override
public Phone makePhone() {
return new PgPhone();
}
@Override
public Pc makePc() {
return new PgPc();
}
}
public class XmFactory implements AbstractFactory{
@Override
public Phone makePhone() {
return new XmPhone();
}
@Override
public Pc makePc() {
return new XmPC();
}
}
测试:
public class Test {
public static void main(String[] args) {
AbstractFactory xmFactory = new XmFactory();
AbstractFactory pgFactory = new PgFactory();
xmFactory.makePc();
xmFactory.makePhone();
pgFactory.makePc();
pgFactory.makePhone();
}
}
结果:
总结:抽象工厂模式可以帮助我们实现不同的产品生产,和工厂方法模式比只是多了其他产品的抽象类和具体实现类,而抽象工厂类只是多了产品实现方法。增强了程序的可扩展性,满足了开闭原则,但是当需要增加一个新的产品时,所有的工厂类都需要进行修改。增加了系统的抽象性和理解难度。我们可以根据自身业务需求情况来选择使用哪一种工厂模式。