程序员

小白的设计模式之旅(工厂模式之工厂方法模式)

2018-08-04  本文已影响0人  蓉漂里的小白

在上一篇中我们学习了简单工厂模式,通过简单工厂的引入我们使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):当需要新增新的产品时,不需要修改框架代码,只需要添加一个新的产品并继承共同的接口,然后再增加一个生产这个产品的工厂

缺点:每次新一个产品都要新增加二个类,一个具体产品类,一个工厂类,如果产品太多,会导致我们的系统出现大量的类,难以维护

上一篇下一篇

猜你喜欢

热点阅读