java工厂模式

转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24460585  http://www.cnblogs.com/archimedes/

1、静态工厂模式

2、简单工厂模式

3、工厂方法模式

4、抽象工厂模式

1、静态工厂模式

这个最常见了,项目中的辅助类,TextUtil.isEmpty等,类+静态方法。详细介绍:略。

2、简单工厂模式

下面以卖肉夹馍为例讲解。

首先你得有个店:RoujiaMoStore

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package com.zhy.pattern.factory.a;  
  2.   
  3. public class RoujiaMoStore  
  4. {  
  5.   
  6.     /** 
  7.      * 根据传入类型卖不同的肉夹馍 
  8.      *  
  9.      * @param type 
  10.      * @return 
  11.      */  
  12.     public RouJiaMo sellRouJiaMo(String type)  
  13.     {  
  14.         RouJiaMo rouJiaMo = null;  
  15.           
  16.         if (type.equals("Suan"))  
  17.         {  
  18.             rouJiaMo = new SuanRouJiaMo();  
  19.   
  20.         } else if (type.equals("Tian"))  
  21.         {  
  22.             rouJiaMo = new TianRouJiaMo();  
  23.         } else if (type.equals("La"))  
  24.         {  
  25.             rouJiaMo = new LaRouJiaMo();  
  26.         }  
  27.           
  28.         rouJiaMo.prepare();  
  29.         rouJiaMo.fire();  
  30.         rouJiaMo.pack();  
  31.         return rouJiaMo;  
  32.     }  
  33.   
  34. }  

然后你得有各种风味的馍馍:

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package com.zhy.pattern.factory.a;  
  2.   
  3. public abstract class RouJiaMo  
  4. {  
  5.     protected String name;  
  6.   
  7.     /** 
  8.      * 准备工作 
  9.      */  
  10.     public void prepare()  
  11.     {  
  12.         System.out.println("揉面-剁肉-完成准备工作");  
  13.     }  
  14.   
  15.     /** 
  16.      * 使用你们的专用袋-包装 
  17.      */  
  18.     public void pack()  
  19.     {  
  20.         System.out.println("肉夹馍-专用袋-包装");  
  21.     }  
  22.     /** 
  23.      * 秘制设备-烘烤2分钟 
  24.      */  
  25.     public void fire()  
  26.     {  
  27.         System.out.println("肉夹馍-专用设备-烘烤");  
  28.     }  
  29. }  

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package com.zhy.pattern.factory.a;  
  2.   
  3. import com.zhy.pattern.factory.a.RouJiaMo;  
  4.   
  5. /** 
  6.  * 辣味肉夹馍 
  7.  *  
  8.  * @author zhy 
  9.  *  
  10.  */  
  11. public class LaRouJiaMo extends RouJiaMo  
  12. {  
  13.     public LaRouJiaMo()  
  14.     {  
  15.         this.name = "辣味肉夹馍";  
  16.     }  
  17. }  

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package com.zhy.pattern.factory.a;  
  2.   
  3.   
  4.   
  5. /** 
  6.  * 酸味肉夹馍 
  7.  *  
  8.  * @author zhy 
  9.  *  
  10.  */  
  11. public class SuanRouJiaMo extends RouJiaMo  
  12. {  
  13.     public SuanRouJiaMo()  
  14.     {  
  15.         this.name = "酸味肉夹馍";  
  16.     }  
  17. }  

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package com.zhy.pattern.factory.a;  
  2.   
  3.   
  4.   
  5. /** 
  6.  * 酸味肉夹馍 
  7.  *  
  8.  * @author zhy 
  9.  *  
  10.  */  
  11. public class SuanRouJiaMo extends RouJiaMo  
  12. {  
  13.     public SuanRouJiaMo()  
  14.     {  
  15.         this.name = "酸味肉夹馍";  
  16.     }  
  17. }  

现在这样的设计,虽然可以支持你卖肉夹馍了,但是有点问题,生产馍的种类和你的RoujiaMoStore耦合度太高了,如果增加几种风味,删除几种风味,你得一直修改sellRouJiaMo中的方法,所以我们需要做一定的修改,此时简单工厂模式就能派上用场了。

我们开始写个简单工厂,把产生馍的过程拿出来:

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package com.zhy.pattern.factory.a;  
  2.   
  3. public class SimpleRouJiaMoFactroy  
  4. {  
  5.     public RouJiaMo createRouJiaMo(String type)  
  6.     {  
  7.         RouJiaMo rouJiaMo = null;  
  8.         if (type.equals("Suan"))  
  9.         {  
  10.             rouJiaMo = new SuanRouJiaMo();  
  11.   
  12.         } else if (type.equals("Tian"))  
  13.         {  
  14.             rouJiaMo = new TianRouJiaMo();  
  15.         } else if (type.equals("La"))  
  16.         {  
  17.             rouJiaMo = new LaRouJiaMo();  
  18.         }  
  19.         return rouJiaMo;  
  20.     }  
  21.   
  22. }  

然后以组合的方式,让Store来使用:

[java]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. package com.zhy.pattern.factory.a;  
  2.   
  3. public class RoujiaMoStore  
  4. {  
  5.     private SimpleRouJiaMoFactroy factroy;  
  6.   
  7.     public RoujiaMoStore(SimpleRouJiaMoFactroy factroy)  
  8.     {  
  9.         this.factroy = factroy;  
  10.     }  
  11.   
  12.     /** 
  13.      * 根据传入类型卖不同的肉夹馍 
  14.      *  
  15.      * @param type 
  16.      * @return 
  17.      */  
  18.     public RouJiaMo sellRouJiaMo(String type)  
  19.     {  
  20.         RouJiaMo rouJiaMo = factroy.createRouJiaMo(type);  
  21.         rouJiaMo.prepare();  
  22.         rouJiaMo.fire();  
  23.         rouJiaMo.pack();  
  24.         return rouJiaMo;  
  25.     }  
  26.   
  27. }  

好了,现在你随便添加什么种类的馍,删除什么种类的馍就和Store无关了,就是么~人家只负责卖馍么~ 这就是简单工厂模式,当然了,大家也都比较熟悉。

3、工厂方法模式

当系统准备为用户提供某个类的子类的实例,又不想让用户代码和该子类形成耦合时,就可以使用工厂方法模式来设计系统。工厂方法模式的关键是在一个接口或抽象类中定义一个抽象方法,该方法返回某个类的子类的实例,该抽象类或接口让其子类或实现该接口的类通过重写这个抽象方法返回某个子类的实例。

适用性

1.当一个类不知道它所必须创建的对象的类的时候。

2.当一个类希望由它的子类来指定它所创建的对象的时候。

3.当类将创建对象的职责委托给多个帮助子类中的某一个,并且你希望将哪一个帮助子类是代理者这一信息局部化的时候。  

参与者

1.Product 定义工厂方法所创建的对象的接口。

2.ConcreteProduct 实现Product接口。

3.Creator 声明工厂方法,该方法返回一个Product类型的对象。 Creator也可以定义一个工厂方法的缺省实现,它返回一个缺省的ConcreteProduct对象。 可以调用工厂方法以创建一个Product对象。

4.ConcreteCreator 重定义工厂方法以返回一个ConcreteProduct实例。

工厂方法模式的结构与使用

模式的结构中包括四种角色:

•抽象产品(Product)

•具体产品(ConcreteProduct)

•构造者(Creator)

•具体构造者(ConcreteCreator) 

模式的UML类图

实战部分

例1】:假设有三个笔芯,分别是红笔芯、蓝笔芯和黑笔芯。用户希望通过圆珠笔来明确笔芯的颜色。

模式的结构的描述与使用 

1.抽象产品(Product): PenCore.java

public abstract class PenCore{
   String color;
   public abstract void writeWord(String s);
}

2.具体产品(ConcreteProduct)_1 : RedPenCore.java

public class RedPenCore extends PenCore{
    RedPenCore(){
      color="红色";
    }
    public void writeWord(String s){
       System.out.println("写出"+color+"的字:"+s);
    }
}

具体产品(ConcreteProduct)_2 : BluePenCore.java

public class BluePenCore extends PenCore{
    BluePenCore(){
      color="蓝色";
    }
    public void writeWord(String s){
       System.out.println("写出"+color+"的字:"+s);
    }
}

具体产品(ConcreteProduct)_3: BlackPenCore.java

public class BlackPenCore extends PenCore{
    BlackPenCore(){
      color="黑色";
    }
    public void writeWord(String s){
       System.out.println("写出"+color+"的字:"+s);
    }
}

3.构造者(Creator): BallPen.java

public abstract class BallPen{
    BallPen(){
       System.out.println("生产了一只装有"+getPenCore().color+"笔芯的圆珠笔");
    }
    public abstract PenCore getPenCore(); //工厂方法
}

4.具体构造者(ConcreteCreator):

RedBallPen.java
public class RedBallPen extends BallPen{
    public PenCore getPenCore(){
       return new RedPenCore();
    }
}
BlueBallPen.java
public class BlueBallPen extends BallPen{
    public PenCore getPenCore(){
       return new BluePenCore();
    }
}
BlackBallPen.java
public class BlackBallPen extends BallPen{
    public PenCore getPenCore(){
       return new BlackPenCore();
    }
}

5.应用 Application.java

public class Application{
    public static void main(String args[]){
       PenCore penCore;
       BallPen ballPen=new BlueBallPen();
       penCore=ballPen.getPenCore();
       penCore.writeWord("你好,很高兴认识你");
       ballPen=new RedBallPen();
       penCore=ballPen.getPenCore();
       penCore.writeWord("How are you");
       ballPen=new BlackBallPen();
       penCore=ballPen.getPenCore();
       penCore.writeWord("nice to meet you");
    }
} 

4.抽象工厂模式

当系统准备为用户提供一系列相关的对象,又不想让用户代码和创建这些对象的类形成耦合时,就可以使用抽象工厂方法模式来设计系统。抽象工厂模式的关键是在一个抽象类或接口中定义若干个抽象方法,这些抽象方法分别返回某个类的实例,该抽象类或接口让其子类或实现该接口的类重写这些抽象方法,为用户提供一系列相关的对象。

适用性

1.一个系统要独立于它的产品的创建、组合和表示时。

2.一个系统要由多个产品系列中的一个来配置时。

3.当你要强调一系列相关的产品对象的设计以便进行联合使用时。

4.当你提供一个产品类库,而只想显示它们的接口而不是实现时。

参与者

1.AbstractFactory 声明一个创建抽象产品对象的操作接口。

2.ConcreteFactory 实现创建具体产品对象的操作。

3.AbstractProduct 为一类产品对象声明一个接口。

4.ConcreteProduct 定义一个将被相应的具体工厂创建的产品对象。 实现AbstractProduct接口。

5.Client 仅使用由AbstractFactory和AbstractProduct类声明的接口

抽象工厂模式的结构与使用

模式的结构中包括四种角色:

•抽象产品(Prodcut)

•具体产品(ConcreteProduct)

•抽象工厂(AbstractFactory)

•具体工厂(ConcreteFactory) 

模式的UML类图

实战部分

例1】:建立一个系统,该系统可以为用户提供西服套装(上衣+裤子)和牛仔套装(上衣+裤子)。

模式的结构的描述与使用 

1.抽象产品(Product) :

 UpperClothes.java

public abstract class UpperClothes{
   public abstract int getChestSize();
   public abstract int getHeight();
   public abstract String getName(); 
}

Trousers.java

public abstract class Trousers{
   public abstract int getWaistSize();
   public abstract int getHeight();
   public abstract String getName(); 
}

2.具体产品(ConcreteProduct)_1: WesternUpperClothes.java

public class WesternUpperClothes extends UpperClothes{
   private int chestSize;
   private int height;
   private String name;
   WesternUpperClothes(String name,int chestSize,int height){
       this.name=name;
       this.chestSize=chestSize;
       this.height=height;
   }
   public int getChestSize(){
       return chestSize;
   }
   public int getHeight(){
       return height;
   }
   public String getName(){
       return name;
   } 
}

2.具体产品(ConcreteProduct)_2: CowboyUpperClothes.java

public class CowboyUpperClothes extends UpperClothes{
   private int chestSize;
   private int height;
   private String name;
   CowboyUpperClothes(String name,int chestSize,int height){
       this.name=name;
       this.chestSize=chestSize;
       this.height=height;
   }
   public int getChestSize(){
       return chestSize;
   }
   public int getHeight(){
       return height;
   }
   public String getName(){
       return name;
   } 
}

2.具体产品(ConcreteProduct)_3: WesternTrousers.java

public class WesternTrousers extends Trousers{
   private int waistSize;
   private int height;
   private String name;
   WesternTrousers(String name,int waistSize,int height){
       this.name=name;
       this.waistSize=waistSize;
       this.height=height;
   }
    public int getWaistSize(){
       return waistSize;
   }
   public int getHeight(){
       return height;
   }
   public String getName(){
       return name;
   } 
}

2.具体产品(ConcreteProduct)_4: CowboyTrousers.java

public class CowboyTrousers extends Trousers{
   private int waistSize;
   private int height;
   private String name;
   CowboyTrousers(String name,int waistSize,int height){
       this.name=name;
       this.waistSize=waistSize;
       this.height=height;
   }
    public int getWaistSize(){
       return waistSize;
   }
   public int getHeight(){
       return height;
   }
   public String getName(){
       return name;
   } 
}

3.抽象工厂(AbstractFactory): ClothesFactory.java

public abstract class ClothesFactory{
    public abstract UpperClothes createUpperClothes(int chestSize,int height);
    public abstract Trousers createTrousers(int waistSize,int height);
}

4.具体工厂(ConcreteFactory): BeijingClothesFactory.java

public class BeijingClothesFactory extends ClothesFactory {
    public UpperClothes createUpperClothes(int chestSize,int height){
         return new WesternUpperClothes("北京牌西服上衣",chestSize,height);
    }
    public Trousers createTrousers(int waistSize,int height){
         return new WesternTrousers("北京牌西服裤子",waistSize,height);
    }
}

ShanghaiClothesFactory.java

public class ShanghaiClothesFactory extends ClothesFactory {
    public UpperClothes createUpperClothes(int chestSize,int height){
         return new WesternUpperClothes("上海牌牛仔上衣",chestSize,height);
    }
    public Trousers createTrousers(int waistSize,int height){
         return new WesternTrousers("上海牌牛仔裤",waistSize,height);
    }
}

5.应用_1: Shop.java

public class Shop{
    UpperClothes cloth;
    Trousers trouser; 
    public void giveSuit(ClothesFactory factory,int chestSize,int waistSize,int height){
       cloth=factory.createUpperClothes(chestSize,height);
       trouser=factory.createTrousers(waistSize,height);
       showMess();
    }
    private void showMess(){
       System.out.println("<套装信息>");
       System.out.println(cloth.getName()+":");
       System.out.print("胸围:"+cloth.getChestSize());
       System.out.println("身高:"+cloth.getHeight());
       System.out.println(trouser.getName()+":");
       System.out.print("腰围:"+trouser.getWaistSize());
       System.out.println("身高:"+trouser.getHeight());
    }
}

5.应用_2: Application.java

public class Application{
    public static void main(String args[]){
       Shop shop=new Shop();
       ClothesFactory factory=new BeijingClothesFactory(); 
       shop.giveSuit(factory,110,82,170);
       factory=new ShanghaiClothesFactory(); 
       shop.giveSuit(factory,120,88,180);
    }
}

抽象工厂模式的优点

•抽象工厂模式可以为用户创建一系列相关的对象,使得用户和创建这些对象的类脱耦。

•使用抽象工厂模式可以方便的为用户配置一系列对象。用户使用不同的具体工厂就能得到一组相关的对象,同时也能避免用户混用不同系列中的对象。

•在抽象工厂模式中,可以随时增加“具体工厂”为用户提供一组相关的对象。


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值