🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
### 什么是工厂方法: 概念:是一种常用的对象创建型设计模式,此模式的核心精神是封装类中不变的部分,提取其中个性化善变的部分为独立类,通过依赖注入以达到解耦、复用和方便后期维护拓展的目的。 定义:定义一个用于创建对象的接口,让子类决定实例化哪一个类。工厂方法使一个类的实例化延迟到其子类。 用处:为了解决下图简单工厂类中使用了判断,如果修改运算类那么就需要修改对应的简单工厂类,违背了开闭原则,进而提出了工厂方法模式(下面只用UML图来解释两个极端至于对应的代码就不做过多解释,图中的关系对应的代码问题请访问:http://blog.csdn.net/shiyiqijialimin/article/details/48128785) ![](https://box.kancloud.cn/2016-04-07_57060889d0ae0.jpg) ### 一对一的极端 ![](https://box.kancloud.cn/2016-04-07_57060889e2eb4.jpg) 上图用到了工厂方法很好的解决了简单工厂中使用判断,违背开闭原则的问题。 这种纯一对一的极端:优点是一个子工厂对应一个算法子类让我们看起来更加清晰;不足是:如果算法很多的时候,需要产生很多的子工厂。 ### 一对多的极端 ![](https://box.kancloud.cn/2016-04-07_5706088a0f697.jpg) 上图很显然也解决了简单工厂类中使用判断,违背开闭原则的问题。但是这里子类中也还是有判断的啊?其实这里是将左边三个类看成了一个整体,如果这个工厂不合适,那么就直接添加额外的子工厂来单独对应一个pizza子类。 这种一对多的极端:优点是将一些可以封装的pizza子类放到了一个子工厂里,省去了子工厂的创建;不足是:如果需要修改其中子工厂的类就又会违背开闭原则。 ### 两极端一起运用: 一对一的工厂方法图是大话设计模式上介绍的,而一对多的图是Head First设计模式上介绍的,两者优势互补,合并到一起运用就非常方便了。 用制作pizza的例子来说明的话就是:对于一对多的工厂不产生修改问题,假设这的多个pizza子类是招牌菜,如果增加新菜,那么就产生一个子工厂对应这一个pizza子类,如下图 ![](https://box.kancloud.cn/2016-04-07_5706088a2388b.jpg) ### 感受: 在学习设计模式的时候,应该从不同的角度去理解它,就好比head first最后讲的复合模式一样,在什么样的环境中用这个模式合适,如何再进行改造就会更好,但是改造的前提还得是我们的六大原则,让我们用好设计模式这个巨人吧。