深入理解设计模式:抽象工厂模式

Posted xuwendong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了深入理解设计模式:抽象工厂模式相关的知识,希望对你有一定的参考价值。

接着上一次的工厂方法模式讲。

假设目前你的程序里面有三个对象IphoneX、IphoneXs、IphoneXR的尺寸,那么你使用工厂模式就已经足够了,因为她们属于同一个品类,都属于苹果,如果在添加一个IPhone2019产品,也只需要把IPhone2019加入到你的苹果工厂里面就够了。

但是如果你程序里面还需要知道华为mate10或者小米8的尺寸。这时候你怎么来创建这些对象呢?这时候工厂模式明显已经不适用了,因为工厂模式是对象都实现了同一个接口,这时候就可以使用抽象工厂模式了。

一、什么是抽象工厂模式

为创建一组相关或相互依赖的对象提供一个接口,而且无需指定他们的具体类。

抽象工厂模式是所有形态的工厂模式中最为抽象和最具一般性的一种形态。抽象工厂模式是指当有多个抽象角色时,使用的一种工厂模式。

抽象工厂模式可以向客户端提供一个接口,使客户端在不必指定产品的具体的情况下,创建多个产品族中的产品对象。

根据里氏替换原则,任何接受父类型的地方,都应当能够接受子类型。因此,实际上系统所需要的,仅仅是类型与这些抽象产品角色相同的一些实例,而不是这些抽象产品的实例。

换言之,也就是这些抽象产品的具体子类的实例。工厂类负责创建抽象产品的具体子类的实例。

技术分享图片

二、抽象工厂模式的应用场景

当一个对象都有相同的约束时,可以使用抽象工厂模式。 
打个比方说,这个工厂的几个产品都需要经过某些共同的步骤和打上相同的商标,这一组产品可以在一个工厂里面生产,减少很多重复的代码在不同的地方都出现多次。

三、抽象工厂模式和工厂方法模式对比

抽象工厂模式的定义:为创建一组相关或相互依赖的对象提供一个接口,而且无需指定它们的具体类。
工厂方法模式的定义:为某个对象提供一个接口,而且无需指定它们的具体类。
都是子类实现接口的方法,并在子类写具体的代码。

工厂方法模式中也是可以有多个具体工厂,也是可以有多个抽象产品,和多个具体工厂、具体产品类。

区别是在抽象工厂接口类中,能创建几个产品对象。 
抽象工厂模式的工厂能创建多个相关的产品对象,而工厂方法模式的工厂只创建一个产品对象。

四、抽象工厂模式的优缺点

优点:
1.它分离了具体的类
2.它使得易于交换产品系列
3.它有利于产品的一致性
缺点:
难以支持新种类的产品。
抽象方法模式的最大缺点就是产品族本身的扩展非常困难。如果在产品族中增加一个新的产品类型,则需要修改多个接口,并影响现已有的工厂类。
上面这句话,有些人不怎么理解,我給大家解释一下,打个比方说,你要在这个工厂创建三个对象,原本只是创建两个对象的,那么你就要在抽象方法中添加一个创建对象的方法,那么所有实现了这个接口的类都是要重新添加这个创建对象的方法,这就是对之前的工厂有影响的原因。

五、抽象工厂模式的实现

首先是抽象工厂,生产对象的抽象。
public abstract class AbstractFactory {
    abstract Size getSize();
}

下面是具体工厂

public class IphoneXFactory: AbstractFactory{

    Size getSize() {
        return new IphoneXSize();
    }
}

public class IphoneXRFactory: AbstractFactory{

    Size getSize() {
        return new IphoneXRSize();
    }
}

public class HuaWeiMate10Factory: AbstractFactory{

    Size getSize() {
        return new HuaWeiMate10Size();
    }
}

public class XiaoMi8Factory: AbstractFactory{

    Size getSize() {
        return new XiaoMi8Size();
    }
}

下面是对象抽象出来的接口

public interface Size {
    public void getSize();
}

最后是我们要生产的对象

public class IphoneXSize: Size {

    public void getSize() {
        System.out.println("IphoneX尺寸.");
    }
}
public class IphoneXRSize: Size {

    public void getSize() {
        System.out.println("IphoneXR尺寸.");
    }
}
public class HuaWeiMate10Size: Size {

    public void getSize() {
        System.out.println("HuaWeiMate10尺寸.");
    }
}
public class XiaoMi8Size: Size {

    public void getSize() {
        System.out.println("小米8尺寸.");
    }
}

客户端调用

public class Test {
    public  static void main(String args[]){
        AbstractFactory factory = new IphoneXFactory();
        factory.getSize(); 
    }
}

六、总结工厂模式

工厂模式可以分为:简单工厂模式,工厂方法模式,抽象工厂模式。

简单工厂模式就没什么好说的了,无非是所有的东西都写在一个类里面,要什么就调用什么,如果要添加新的方法也是到这类里面添加,代码很多,看起来也是很乱,就像一个大工厂,什么都在里面。扩展性很低。

而工厂方法模式,把说明的理论和生产的东西就分开一点。抽象工厂模式是工厂方法模式的升级。

总结:工厂模式与抽象工厂模式都属于创建型模式,在工厂模式中弥补了简单工厂模式的缺陷(不符合开闭原则),而在抽象工厂模式中弥补了工厂模式的不足(一个工厂只能生产一种产品)。

以上是关于深入理解设计模式:抽象工厂模式的主要内容,如果未能解决你的问题,请参考以下文章

深入理解设计模式-简单工厂模式vs工厂方法模式vs抽象工厂模式对比讲解

深入理解设计模式-简单工厂模式vs工厂方法模式vs抽象工厂模式对比讲解

深入理解设计模式:抽象工厂模式

设计模式重新理解简单工厂模式工厂模式抽象工厂模式

深入理解Java的三种工厂模式

初探PHP设计模式