摘要:工厂方法模式和策略的模式有什么区别区别在于,策略模式强调的是提供不同的策略方案,而工厂方法模式强调的是产品本身。
女朋友dodo闹脾气,气势汹汹的说“我要吃雪糕”。笔者心里啊乐滋滋的,一支雪糕就能哄回来,不亦乐乎?!
但是,雪糕买回来了,她竟然说“不想吃雪糕了,突然想吃披萨”。呵呵了,憋了一股劲“没问题”,又屁颠屁颠的去把披萨买回来。
世事难料,dodo同学又放大招了,“披萨太上火了,我要吃芝士蛋糕”。
这时候,工厂方法模式该上场了,使用它可以完美的解决不断的产品变更。工厂方法模式是怎么样的?而工厂模式又是怎样解决产品变更呢?一起来看看...
一、工厂方法模式 定义定义一个创建对象的工厂接口,工厂方法将实例化推迟到子类中。
定义总是抽象的,先放出工厂方法模式的UML图如下所示:
从上图可以看出,工厂方法模式涉及到以下四个角色的概念:
- 抽象工厂角色:工厂方法模式的核心,创建产品的工厂类必须实现该接口。
- 具体工厂角色:该角色实现了抽象工厂接口,具体如何创建产品类就是在该实现类完成。
- 抽象产品角色:所有产品类的超类,负责实现产品共性的抽象定义。
- 具体产品角色:该角色实现了抽象产品接口,负责具体的不同产品业务逻辑。
二、实战 上代码抽象工厂角色代码如下:
public interface Factory { // 传入参数的是产品类型,这里返回产品类的抽象工厂类Product public Product factory(String productType); }
这里做出生产雪糕、披萨的工厂,有了工厂才能生产对应的产品,具体工厂角色代码如下:
// 雪糕的工厂,负责生产雪糕 public class IceCreamFactory implements Factory { @Override public Product factory() { return new IceCream(); } }
上面看到抽象角色Product,看代码:
public interface Product { public void product(); }
具体角色代码如下:
public class IceCream implements Product { @Override public void product() { /** * 具体的业务逻辑 */ System.out.println("雪糕做好了!!"); } }
OK,涉及到工厂方式模式系统的代码基本完成,下面看看客户端怎么使用工厂模式,雪糕准备就绪:
public class Client { public static void main(String[] args){ // 生产雪糕 Factory iceCreamFactory = new IceCreamFactory(); Product iceCream = iceCreamFactory.factory(); iceCream.product(); } }
运行客户端代码,结果如下:
雪糕做好了!!扩展
雪糕的order已经完成!雪糕不吃,吃披萨?OK,现在就做披萨。同样的先实现抽象工厂和抽象产品角色。
披萨工厂实现如下:
// 披萨的工厂,负责生产披萨 public class PizzaFactory implements Factory { @Override public Product factory() { return new Pizza(); } }
接下来就是披萨:
public class Pizza implements Product { @Override public void product() { /** * 具体的业务逻辑 */ System.out.println("披萨做好了!!"); } }
现在我们在客户端中实现生产披萨,代码如下:
public class Client { public static void main(String[] args){ // 生产雪糕 Factory iceCreamFactory = new IceCreamFactory(); Product iceCream = iceCreamFactory.factory(); iceCream.product(); // 生产披萨 Factory pizzaFactory = new PizzaFactory(); Product pizza = pizzaFactory.factory(); pizza.product(); } }
运行结果如下:
雪糕做好了!!三、工厂方法模式的优缺点 优点披萨做好了!!
1)优秀的扩展性。假如披萨不想吃了,想吃芝士蛋糕,只需要增加芝士蛋糕的具体工厂和具体产品类,不会影响其他产品的生产。
2)大降低代码的耦合度,客户端最终得到的是产品本身,而不需要知道和操作产品的生产过程。
缺点1)增加新产品时,需要增加具体的工厂类和具体的产品类,当产品数量多的时候就会造成系统的复杂度增大,也增加了对系统理解的难度。
四、比较跟策略模式对比:问得最多的一个问题。工厂方法模式和策略的模式有什么区别?区别在于,策略模式强调的是提供不同的策略方案,而工厂方法模式强调的是产品本身。
策略模式接下来也会说到,把策略模式吃透了,回头再跟工厂方法模式对比的时候就恍然大悟了。
总结首先,上一篇的单例模式很多人都给我提了很不错的建议,也在这篇文章中改进了。工厂方式模式的使用率也非常高,掌握它对把握系统架构会有比较大的提升。下一篇要分享的是:建造者模式
设计模式Java源码GitHub下载:https://github.com/jetLee92/DesignPattern
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/67900.html
摘要:孙膑心里一万个草泥马在奔腾,差点没噎死自己滚一边去,我们这盘跟他赛马开始,策略模式上场。在设计模式之禅中的提出通过策略枚举和反射机制对策略模式进行改良,膜拜了但是要添加或淘汰策略,还是得去对枚举进行修改,也不符合开闭原则。 今天给大家说说田忌赛马的故事。如有雷同,纯属巧合!话说在战国时期,群雄割据,硝烟四起,茶余饭后还是少不了娱乐活动的,其中赛马是最火爆的。一天,孙膑看到田忌像个死鸡似...
摘要:我认为按书上的顺序比较好理解因为简单静态工厂模式是在工厂方法模式上缩减,抽象工厂模式是在工厂方法模式上再增强。所以我就先讲工厂方法模式了。抽象工厂模式抽象工厂模式就比较复杂了,我们一般的应用都写不到。 前言 只有光头才能变强 回顾前面: 给女朋友讲解什么是代理模式 包装模式就是这么简单啦 单例模式你会几种写法? 昨天写了单例模式了,今天是时候写工厂模式啦~ 工厂模式我个人认为其实比...
摘要:汽车本身就是复杂产品对象,其制造过程可以形象的表示建造者模式。另一辆法拉利,。法拉利具体建造者代码如下构造法拉利的第一部分。咻咻法拉利已造好三建造者模式的优缺点优点降低代码耦合度。 在未上大学之前,一直有个梦想I have a dream!,就是能成为一位汽车工程师,一直幻想着开着自己设计的汽车飞奔在公路上,迷倒了万千少女。咳咳~~虽然现在没实现我的dream,但梦想还是得有的。 说到...
阅读 2962·2021-09-22 14:59
阅读 1754·2021-09-22 10:02
阅读 2077·2021-09-04 16:48
阅读 2152·2019-08-30 15:53
阅读 2934·2019-08-30 11:27
阅读 3387·2019-08-29 18:35
阅读 879·2019-08-29 17:07
阅读 2648·2019-08-29 13:27