设计模式三:工厂方法模式、抽象工厂模式对比

转自知乎https://www.zhihu.com/question/20367734/answer/115807228 并整理
文中例子以鼠标,键盘,耳麦为产品,惠普,戴尔为工厂

简单工厂模式

简单工厂模式不是23种里的一种,简而言之,就是有一个专门生产某个产品的类。
比如下图中的鼠标工厂,专业生产鼠标,给参数0,生产戴尔鼠标,给参数1,生产惠普鼠标。

工厂方法模式

工厂方法模式也就是鼠标工厂是个父类,有生产鼠标这个方法。
戴尔鼠标工厂、惠普鼠标工厂继承它,可以分别生产戴尔鼠标、惠普鼠标。
生产哪种鼠标不再由参数决定,而是创建鼠标工厂时,由戴尔鼠标工厂创建。
后续直接调用鼠标工厂.生产鼠标()即可。

抽象工厂模式

抽象工厂模式也就是不仅生产鼠标,同时生产键盘。
也就是PC厂商是个父类,有生产鼠标,生产键盘两个方法。
戴尔工厂、惠普工厂继承它,可以分别生产戴尔鼠标+戴尔键盘、惠普鼠标+惠普键盘。
创建工厂时,若由戴尔工厂创建,
后续工厂.生产鼠标()则生产戴尔鼠标,工厂.生产键盘()则生产戴尔键盘。

在抽象工厂模式中,增加一个工厂

假设我们增加华硕工厂,则我们需要增加华硕工厂,和戴尔工厂一样,继承PC厂商。
之后创建华硕鼠标,继承鼠标类。创建华硕键盘,继承键盘类。
即可。

在抽象工厂模式中,增加一个产品

假设我们增加耳麦这个产品,则首先我们需要增加耳麦这个父类,再加上戴尔耳麦,惠普耳麦这两个子类。
之后在PC厂商这个父类中,增加生产耳麦的方法。最后在戴尔工厂,惠普工厂这两个类中,分别实现生产戴尔耳麦,惠普耳麦的功能。

产品等级结构、产品族

  • 产品等级结构:即产品的继承结构。在工厂方法模式中抽象类是鼠标,其子类有戴尔鼠标、惠普鼠标,则抽象鼠标与具体品牌的鼠标之间构成了一个产品等级结构,抽象鼠标是父类,而具体品牌的鼠标是其子类。

  • 产品族:在抽象工厂模式中,产品族是指由同一个工厂生产的,位于不同产品等级结构中的一组产品,如戴尔工厂生产的戴尔鼠标、戴尔键盘,戴尔鼠标位于鼠标产品等级结构中,戴尔键盘位于键盘产品等级结构中,戴尔鼠标、戴尔键盘构成了一个产品族。


定义描述及图片来源 http://blog.csdn.net/lovelion/article/details/9319323

对比总结

工厂方法模式 抽象工厂模式
只有一个产品等级结构 有多个产品等级结构(产品族)
只有一个抽象产品类 有多个抽象产品类
每个具体工厂可创建一个产品类实例 每个具体工厂可创建多个产品类实例






0%