快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

设计模式之Factory深入研究






今天我去市场,要决定是买水果等产品,还是选择种水果的产品。详细怎么操作自己选择。来到市场,我发现主要有一些水果:苹果(Apple),葡萄(Grape)和鸭梨(Pear)。到底买什么好呢?我一阵思量。俗话说:“饭后一只烟,胜过活神仙。饭后吃苹果,西施见我躲。”为了老婆的美丽,我决定买苹果。

 





下面开始Factory模式研究,当然是用我上面举的例子来说明。

Simple Factory模式





专门定义一个类来负责创建其它类的实例,被创建的实例通常都具有共同的父类。 

Factory Method模式





将对象的创建交由父类中定义的一个标准方式来完成,而不是其构造函数,毕竟应该创建何种对象由详细的子类负责决定。 

Abstract Factory模式





提供一个共同的接口来创建相互关联的多个对象。

 





一、Simple Factory模式:





1、  在这里,我们先定义水果(Fruit)接口:

public interface Fruit {

  void plant();  //水果是被种植的

  void enableEat();  //水果能吃

}

2、  苹果(Apple)是对水果(Fruit)接口的实现:

public class Apple implements Fruit{

  public void plant(){

    System.out.println("种苹果!");

  }

  public void enableEat(){

    System.out.println("苹果好吃!");

  }

}

3、  葡萄(Grape)是对水果(Fruit)接口的实现:

public class Grape implements Fruit{

  public void plant(){

    System.out.println("种葡萄!");

  }

  public void enableEat(){

    System.out.println("葡萄好吃!");

  }

}

4、  鸭梨(Pear)是对水果(Fruit)接口的实现:

public class Pear implements Fruit{

  public void plant(){

    System.out.println("种鸭梨!");

  }

  public void enableEat(){

    System.out.println("鸭梨好吃!");

  }

}

5、定义买水果(BuyFruit)这一过程类:

public class BuyFruit {

  /**

  简朴工厂方式

  */

  public static Fruit buyFruit(String which){

    if (which.equalsIgnoreCase("apple")) {  //假如是苹果,则返回苹果实例

      return new Apple();

    }

    else if (which.equalsIgnoreCase("pear")){  //假如是鸭梨,则返回鸭梨实例

      return new Strawberry();

    }

    else if (which.equalsIgnoreCase("grape")) { //假如是葡萄,则返回葡萄实例

      return new Grape();

    }

    else{

      return null;

    }

  }

}

6、  编写测试类:

public class FruitTest {

  public static void  main(String args[]){

    BuyFruit buy = new BuyFruit();   //开始买水果这个过程

    buy.buyFruit("apple").enableEat(); //调用苹果的enableEat()方式

  }

}

7、  说明:

A:我要购买苹果,只需向工厂角色(BuyFruit)哀求即可。而工厂角色在接到哀求后,会自行判定创建和提供哪一个产品。

B:但是对于工厂角色(BuyFruit)来说,增加新的产品(比如说增加草莓)就是一个痛苦的过程。工厂角色必须知道每一种产品,如何创建它们,以及何时向客户端提供它们。换言之,接纳新的产品意味着修改这个工厂。

C:因此Simple Factory模式的开放性比较差。

有什么办法可以解决这个问题吗?那就需要Factory Method模式来为我们服务了。

二、Factory Method模式:





1、同样,我们先定义水果(Fruit)接口:

public interface Fruit {

  void plant();  //水果是被种植的

  void enableEat();  //水果能吃

}

2、苹果(Apple)是对水果(Fruit)接口的实现:

public class Apple implements Fruit{

  public void plant(){

    System.out.println("种苹果!");

  }

  public void enableEat(){

    System.out.println("苹果好吃!");

  }

}

3、葡萄(Grape)是对水果(Fruit)接口的实现:

public class Grape implements Fruit{

  public void plant(){

    System.out.println("种葡萄!");

  }

  public void enableEat(){

    System.out.println("葡萄好吃!");

  }

}

4、鸭梨(Pear)是对水果(Fruit)接口的实现:

public class Pear implements Fruit{

  public void plant(){

    System.out.println("种鸭梨!");

  }

  public void enableEat(){

    System.out.println("鸭梨好吃!");

  }

}

5、在这里我们将买水果(BuyFruit)定义为接口类:

public interface BuyFruit{

  /**

  工厂方式

  */

  public Fruit buyFruit();   //定义买水果这一过程

}

6、买苹果是(BuyApple)对买水果(BuyFruit)这个接口的实现

public class BuyApple implements BuyFruit{

  public Fruit buyFruit(){

    return new Apple();  //返回苹果实例

}

}

7、买鸭梨是(BuyPear)对买水果(BuyFruit)这个接口的实现

public class BuyPear implements BuyFruit{

  public Fruit BuyPear (){

    return new Pear();  //返回鸭梨实例

}

}

8、买葡萄是(BuyGrape)对买水果(BuyFruit)这个接口的实现

public class BuyGrape implements BuyFruit{

  public Fruit BuyGrape (){

    return new Grape ();  //返回葡萄实例

}

}

9、编写测试类:

public class FruitTest {

  public static void  main(String args[]){

    BuyApple buy = new BuyApple(); //开始买水果这个过程

    buy.buyFruit().enableEat();      //调用苹果的enableEat()方式

  }

}

10、说明:

A:工厂方式模式和简朴工厂模式在结构上的不同是很明显的。工厂方式模式的核心是一个抽象工厂类,而简朴工厂模式把核心放在一个详细类上。工厂方式模式可以答应很多详细工厂类从抽象工厂类中将创建行为继续下来,从而可以成为多个简朴工厂模式的综合,进而推广了简朴工厂模式。

B:工厂方式模式退化后可以变得很像简朴工厂模式。设想假如异常确定一个系统只需要一个详细工厂类,那么就不妨把抽象工厂类合并到详细的工厂类中去。由于反正只有一个详细工厂类,所以不妨将工厂方式改成为静态方式,这时候就得到了简朴工厂模式。

C:假如需要加入一个新的水果,那么只需要加入一个新的水果类以及它所对应的工厂类。没有必要修改客户端,也没有必要修改抽象工厂角色或者其他已有的详细工厂角色。对于增加新的水果类而言,这个系统完全支持“开-闭”原则。

D:对Factory Method模式而言,它只是针对一种类别(如本例中的水果类Fruit),但假如我们还想买肉,那就不行了,这是就必须要Abstract Factory Method模式帮忙了。

三、Abstract Factory模式





1、同样,我们先定义水果(Fruit)接口:

public interface Fruit {

  void plant();  //水果是被种植的

  void enableEat();  //水果能吃

}

2、苹果(Apple)是对水果(Fruit)接口的实现:

public class Apple implements Fruit{

  public void plant(){

    System.out.println("种苹果!");

  }

  public void enableEat(){

    System.out.println("苹果好吃!");

  }

}

3、葡萄(Grape)是对水果(Fruit)接口的实现:

public class Grape implements Fruit{

  public void plant(){

    System.out.println("种葡萄!");

  }

  public void enableEat(){

    System.out.println("葡萄好吃!");

  }

}

4、鸭梨(Pear)是对水果(Fruit)接口的实现:

public class Pear implements Fruit{

  public void plant(){

    System.out.println("种鸭梨!");

  }

  public void enableEat(){

    System.out.println("鸭梨好吃!");

  }

}

5、  定义肉(Meat)接口:

public interface Meat {

  void feed();  //肉是喂养的

  void enableEat();  //肉能吃

}

6、  猪肉(BigMeat)是对肉(Meat)接口的实现:

public class BigMeat implements Meat{

  public void feed(){

    System.out.println("养猪!");

  }

  public void enableEat(){

    System.out.println("猪肉好吃!");

  }

}

7、  牛肉(CowMeat)是对肉(Meat)接口的实现:

public class CowMeat implements Meat {

  public void feed(){

    System.out.println("养牛!");

  }

  public void enableEat(){

    System.out.println("牛肉好吃!");

  }

}

8、  我们可以定义买货人(Buyer)接口:

public interface Buyer {

  /**

   买水果工厂方式

   */

  public Fruit buyFruit(Fruit whichFruit);

  /**

   买肉的工厂方式

   */

  public Meat buyMeat(Meat whichMeat);

}

9、  我(MyBuyer)是对买货人(Buyer)接口的实现:

public class MyBuyer implements Buyer{

  /**

   买水果工厂方式

   */

  public Fruit buyFruit(Fruit whichFruit){

     return whichFruit;

  }

  /**

   买肉的工厂方式

   */

  public Meat buyMeat(Meat whichMeat){

     return whichMeat;

  }

}

10、编写测试类:

public class MyBuyerAbstractTest {

  public static void  main(String args[]){

    Fruit apple = new Apple();   //苹果实例

    Meat big = new BigMeat();  //猪肉实例

    MyBuyer my = new MyBuyer();  //我是买者的实例

    my.buyFruit(apple).enableEat();  //我买苹果

    my.buyMeat(big).enableEat();    //我买猪肉

  }

}

11、说明:

A:抽象工厂模式可以向客户端提供一个接口,使得客户端在不必指定产品的详细类型的情况下,创建多个产品族中的产品对象。这就是抽象工厂模式的用意。

B:抽象工厂模式是所有形态的工厂模式中最为抽象和最具一般性的一种形态。






返回类别: 教程
上一教程: Java JDBC连接的一个例子
下一教程: 利用xml+xsl迅速生成大量JSP的常用代码的方式.

您可以阅读与"设计模式之Factory深入研究"相关的教程:
· 深入浅出基于Java的解释器设计模式
· 设计模式之Facade??家庭篇
· java设计模式之创建模式--singleton
· 使用UML编写Java 设计模式例子 FactoryMethod Pattern
· 设计模式之Singleton
    微笑服务 优质保证 索取样品