在上一篇中我们学习了简单工厂模式,通过简单工厂的引入我们使MoonCakeStore类遵循了对修改关闭的原则。在简单工厂模式中,我们所有的月饼创建都放在了工厂中进行,那如果要增加或删除月饼时,简单工厂类还是会被我们频繁的修改,似乎这SimpleFactory并没有满足我们的“对修改关闭对扩展开放原则”
接下来,我们再思考一个问题如果有一天我们的月饼店做的大了,有了加盟店而且每个新店都要把月饼进行本地化,比如:内蒙古:五仁月饼要加点牛肉,四川:五仁月饼要加点辣椒,上海:五仁月饼要加点糖。这样的需求出现后,我们的SimpleFactory彻底满足不了我们的需求了。
今天我们来学习一个新的设计模式之工厂方法模式来解决 1:Factory类没有满足对修改关闭对扩展开放原则,2:满足可以添加加盟店的需求。
1:什么工厂方法模式
定义:定义一个创建对象的接口,由子类来决定要实例化哪一个类。工厂方法模式让类的实例化推迟到子类
类图:
抽象产品类:是所有产品的共同接口,所有的具体产品都需要实现这 个接口,这样一来创建者就只需要依赖这个接口,不需要维护一大堆的具体产品
具体产品类:实现了产品接口,定义具体的产品
抽象创建者类:是一个抽象类,在类中定义了一个抽象的生产产品方法然后交给子类去实现
具体创建者类:用来生产具体的产品, 继承于抽象创建者类并实现生产具体产品的方法
2:实现工厂方法模式
1:修改MoonCakeStore(添加创建对象接口,交由子类实现),使其变成Creator类
2:添加四川,内蒙,北京的特色加盟店
3:创建四川风味牛肉月饼,内蒙风味牛肉月饼,北京风味牛肉月饼
4:下面让我们来生产三个不同风味的牛肉月饼
3:工厂方法的使用场景
1):在你的工程里,当客户端需要创建一个对象,但不又想让客户端知道创建这个对象的具体类是什么的时候,就可以使用工厂方法来代替,(因为使用工厂方法后,客户端只需要知道这些产品的抽象接口如:IMoonCake,和可以生产这个产品的工厂即可)
2):在工程里,当一个类需要他的子来创建指定的对象时(我们定义了MoonCakeStore,但是MoonCake的创建却是交给他的子SCMCStore,NMMCStore来创建)
4:工厂方法的优缺点
优点:
1):工厂方法提供产品的创建,隐藏了产品的具体类名,是产品的“使用“和“实现”相互独立,提供了一套框架,让子类去创建产品
2):当需要新增新的产品时,不需要修改框架代码,只需要添加一个新的产品并继承共同的接口,然后再增加一个生产这个产品的工厂
缺点:每次新一个产品都要新增加二个类,一个具体产品类,一个工厂类,如果产品太多,会导致我们的系统出现大量的类,难以维护