`
youfengkai
  • 浏览: 26986 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

工厂方法模式

阅读更多

工厂方法模式定义了一个创建对象的接口,但由子类决定要实例化的类是哪一个。工厂方法把实例化推迟到子类。
把创建的对象认识为产品,“由子类决定要实例化的类是哪一个。工厂方法把实例化推迟到子类”意味着使用产品的客户代码,依赖的是产品的抽象类,而不是具体化的产品。
Java提供了new关键字,当我们在程序中需要使用一个对象时,就会想到它。
Pizza orderPizza() {
    Pizza pizza = new Pizza();
    pizza.prepare();
    pizza.bake();
    pizza.cut();
    pizza.box();
    return pizza;
}

Pizza orderPizza(String type) {
    Pizza pizza;
    // 变化的部分
  
if (type.equals("cheese")) {
        pizza = new CheesePizza();
    } else if (type.equals("greek")) {
        pizza = new GreekPizza();
    } else if (type.equals("pepperoni")) {
        pizza = new PepperoniPizza();
    }

    pizza.prepare();
    pizza.bake();
    pizza.cut();
    pizza.box();
    return pizza;
}

  New没有什么不对的,关键在于orderPizza依赖于具体实现类。考虑到程序的扩展性,未来我们要创建哪些类型的Pizza对象是要经常改变的,对应于程序中if语句部分是要经常改变的。
  这违反了OCP原则,没有对修改关闭。解决方法:应用设计原则:封装变化,把程序中变化的部分和不变的部分隔离开。要把程序中创建产品的部分封装起来,封装对象的创建。
  定义简单工厂:

   public class SimplePizzaFactory {
        public Pizza createPizza(String type) {
            Pizza pizza = null;
            
            if (type.equals("cheese")) {
                pizza = new CheesePizza();
            } else if (type.equals("pepperoni")) {
                pizza = new PepperoniPizza();
            } else if (type.equals("clam")) {
                pizza = ClamPizza();
            } else if (type.equals("veggie")) {
                pizza = new VeggiePizza();
            }
            return pizza;
        }
    }

     该工厂提供了创建对象的接口createPizza(String type)。下面我们看一下,该简单工厂在PizzaStore中的应用:

     public class PizzaStore {
        SimpPizzaFactory factory;
       
        public PizzaStore(SimplePizzaFactory factory ) {
             this.factory = factory;
        }
       
        public Pizza orderPizza(String type) {
            Pizza pizza;
            pizza = factory.createPizza(type);
           
            pizza.prepare();
            pizza.bake();
            pizza.cut();
            pizza.box();
            return pizza;
        }
       
        //这里是其他方法
    }

      PizzaStore中,使用简单工厂来创建Pizza对象。简单工厂好处说明:
      把创建产品的代码封装到一个类中,当以后产品实现或者产品的种类改变时,只需要修改这个类即可,客户端PizzaStore代码不变。该简单工厂可以被许多客户使用。

    public abstract class PizzaStore {
           public Pizza orderPizza(String type) {
                Pizza pizza;

                pizza = createPizza(type);
                pizza.prepare();
                pizza.bake();
                pizza.cut();
                pizza.box();

                return pizza;
          }

          // 在PizzaStore中工厂方法createPizza是抽象的
          abstract Pizza createPizza(String type);
    }

 

    public class NYPizzaStore extends PizzaStore {
          Pizza createPizza(String item) {
               if (item.equals("cheese")) {
                     return new NYStyleCheesePizza();
                } else if (item.equals("veggie")) {
                     return new NYStyleVeggiePizza();
                } else if (item.equals("clam")) {
                     return new NYStyleClamPizza();
                } else if (item.equals("pepperoni")) {
                     return new NYStylePepperoniPizza();
                } else
                    return null;
          }
    }


    public class ChicagoPizzaStore extends PizzaStore {
          Pizza createPizza(String item) {
             if (item.equals("cheese")) {
                   return new ChicagoStyleCheesePizza();
             } else if (item.equals("veggie")) {
                   return new ChicagoStyleVeggiePizza();
             } else if (item.equals("clam")) {
                   return new ChicagoStyleClamPizza();
             } else if (item.equals("pepperoni")) {
                   return new ChicagoStylePepperoniPizza();
             } else
                     return null;
         }
    }

 

      PizzaStore nyPizzaStore = new NYPizzaStore();

      nyPizzaStore.orderPizza("cheese");

       对工厂方法的认识:

     超类PizzaStore 中提供了抽象工厂方法abstract Pizza createPizza(String type),该抽象工厂方法返回一个产品Pizza,该产品是抽象的。这样的话,工厂方法将客户(也就是PizzaStore中的代码,orderPizza())和实际创建具体产品的代码分离开来。

     将一个orderPizza()方法和一个工厂方法联合起来,就可以成为一个框架。工厂方法模式中体现了平行的类层次:产品类和创建者类。抽象类:Pizza和PizzaStore,具体子类:NYStyle*Pizza、ChicagePizzaStore(*代表Cheese等种类)和NyPizzaStore、ChicagoPizzaStore。抽象创建者对应抽象产品,具体创建者对应具体产品。这就是类的层次结构。

     简单工厂模式和工厂方法模式的比较:

        1. 客户通过组合简单工厂,由工厂来创建产品。而工厂方法模式中,存在着继承关系,抽象类提供抽象工厂方法接口,而由具体子类去创建具体的产品。

     2. 简单工厂模式实现了客户端的OCP原则,但是如果产品发生变化,简单工厂本身代码仍然需要修改,因此简单工厂没有完全实现OCP原则。工厂方法模式中,当有新的产品出现时,只需要扩展出新的创建者对应该新的具体产品即可,完全符合OCP原则。

     4. 工厂方法模式体现了类层次结构。包括创建者类和产品类的层次对应关系。创建者类通过工厂方法来创建具体产品,并且创建者类可以应用框架,包含使用产品的客户代码(这个很强,否则只用来创建产品将是一种退化,我认为)。而简单工厂类只是创建产品,本身并不使用。

     3. 两者都封装了对象的创建,使客户与具体创建产品的代码解耦。

     最后,DIP原则(依赖倒置原则):要依赖抽象,不要依赖具体类。不能让高层组件以来低层组件,而且,不管高层或底层组件,“两者”都应该依赖于抽象。工厂方法模式是遵循DIP原则最有威力的技巧之一。

分享到:
评论

相关推荐

    工厂模式:简单工厂模式、工厂方法模式、抽象工厂模式

    工厂模式分为三种主要类型:简单工厂模式、工厂方法模式和抽象工厂模式。 1. **简单工厂模式** 简单工厂模式是最简单的工厂模式实现,它提供一个静态方法或者类来创建对象,这个类通常被称为“工厂”。用户只需要...

    简单工厂模式-工厂方法模式-抽象工厂模式

    在软件设计模式中,工厂模式是一组非常基础且实用的设计模式,主要分为简单工厂模式、工厂方法模式和抽象工厂模式。这些模式都是为了解决对象创建的问题,通过封装对象的创建过程,使得代码更加灵活,易于扩展和维护...

    工厂方法模式和抽象工厂模式的区别

    工厂方法模式和抽象工厂模式是两种常见的设计模式,它们都属于创建型模式,用于解决对象的创建问题。在软件设计中,这两种模式都是用来隔离对象的创建和使用,以提高系统的灵活性和可扩展性。 首先,工厂方法模式的...

    工厂方法模式uml类图

    java设计模式 工厂方法模式uml类图,一张图就让你秒懂工厂方法模式

    设计模式-工厂方法模式

    工厂方法模式作为创建型模式中的一种,提供了一种创建对象的优雅方式,它不仅使对象的创建与使用分离,还极大地提高了系统的扩展性和灵活性。本文将深入探讨工厂方法模式的内部机制,以及通过反射和配置文件技术增强...

    软件设计之工厂方法模式,源代码

    ### 软件设计之工厂方法模式解析及Java实现 #### 一、工厂方法模式概述 工厂方法模式(Factory Method Pattern)是一种常用的面向对象设计模式,属于创建型模式之一。它提供了一种创建对象的最佳方式。在工厂方法...

    java工厂方法模式

    Java工厂方法模式 Java工厂方法模式是一种创建型模式,它属于类的创建型模式。该模式的主要思想是,父类负责定义创建对象的公共接口,而子类则负责生成具体的对象。这样做的目的是将类的实例化操作延迟到子类中完成...

    工厂方法模式的C语言实现

    工厂方法模式是一种设计模式,属于创建型模式,它提供了一种创建对象的最佳方式。在工厂方法模式中,当我们创建对象时,不会直接实例化具体的产品类,而是通过一个工厂类来创建。这样做的好处是,当需要添加新的产品...

    抽象工厂模式+工厂方法模式+策略模式+类图实现手机加工厂

    本文将探讨三个重要的设计模式:抽象工厂模式、工厂方法模式以及策略模式,并结合一个实际的场景——手机加工厂,来具体阐述它们的应用。 首先,我们来看**抽象工厂模式**。这个模式主要用于创建相关或依赖对象的...

    用工厂方法模式重构简易计算器 源代码+实验报告

    《工厂方法模式在简易计算器重构中的应用》 在软件工程中,设计模式是解决常见问题的模板,它们为程序员提供了一种标准化的解决方案。工厂方法模式(Factory Method Pattern)是面向对象设计模式的一种,它在实际...

    工厂方法模式源文件

    工厂方法模式是面向对象设计模式中的行为模式,它属于创建型模式的一种,主要解决的是当一个类不知道它所必须创建的对象的类的时候,或者当一个类希望由它的子类来决定实例化哪个类的时候,如何封装这个实例化过程的...

    工厂方法模式Demo

    工厂方法模式是一种面向对象的设计模式,属于创建型模式,它提供了一种创建对象的最佳方式。在工厂方法模式中,一个工厂类负责创建所关心的对象,而客户端代码则使用这些对象,而不必知道对象是如何被创建的。这种...

    设计模式——工厂方法模式

    工厂方法模式是面向对象设计模式中的一种,它属于创建型模式,主要解决的是当系统需要创建的对象具有多种类型,而具体创建哪种类型的对象在运行时才能确定的问题。在这个压缩包中,`FactoryMethod`可能包含了Java...

    设计模式之工厂方法模式

    工厂方法模式是设计模式中的创建型模式之一,它在软件工程中扮演着非常重要的角色,尤其是在C#这样的面向对象编程语言中。工厂方法模式提供了一种封装对象创建过程的方法,使得具体的创建过程延迟到子类中进行,从而...

    工厂方法模式工厂方法模式

    工厂方法模式是一种创建型设计模式,它提供了一种创建对象的最佳方式。在工厂方法模式中,一个工厂类负责创建对象,但允许子类决定实例化哪个类。工厂方法让类的实例化推迟到子类中进行,使得代码更加灵活且易于扩展...

    工厂方法模式应用案例

    工厂方法模式是面向对象设计模式中的行为模式之一,它提供了一种创建对象的最佳方式。在工厂方法模式中,我们创建对象时不直接实例化具体的产品,而是通过一个抽象工厂类来调用具体工厂子类的方法来生成对应的具体...

    工厂方法模式java实例demo

    工厂方法模式是面向对象设计模式中的行为模式,它提供了一种创建对象的最佳方式。在工厂方法模式中,我们在创建对象时不会对客户端暴露创建逻辑,而是引用一个共同的接口来指向新创建的对象。这种模式是类的创建模式...

    工厂方法模式 .net源码案例

    工厂方法模式是设计模式中的一种创建型模式,它在软件工程中扮演着非常重要的角色,尤其是在.NET框架下。这个模式的主要目标是定义一个用于创建对象的接口,让子类决定实例化哪一个类,使得代码更加灵活,易于扩展,...

    工厂方法模式Java代码

    工厂方法模式是设计模式中的创建型模式,它提供了一种创建对象的最佳方式。在这个模式中,一个工厂类负责创建对象,而具体的创建过程被延迟到子类中实现。这种模式的关键在于封装了对象的创建过程,并允许在运行时...

    IOS 工厂方法模式代码Demo

    在iOS开发中,工厂方法模式是一种重要的设计模式,它属于创建型模式,主要用来解决对象创建过程中的灵活性问题。这个“IOS 工厂方法模式代码Demo”是为开发者提供了一个直观的例子,帮助他们理解并应用这种模式。让...

Global site tag (gtag.js) - Google Analytics