Java设计模式之工厂方法模式(2)

工厂方法模式定义了一个创建产品对象的工厂接口,将实际创建工作推迟到子类。它通过抽象工厂角色来进一步抽象化,使得系统可以在不修改具体工厂角色的情况下引进新产品。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一 、工厂方法(Factory Method)模式
     工厂方法模式的意义是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类当中。核心工厂类不再负责产品的创建,这样核心类成为一个抽象工厂角色,仅负责具体工厂子类必须实现的接口,这样进一步抽象化的好处是使得工厂方法模式可以使系统在不修改具体工厂角色的情况下引进新的产品。

    工厂方法(Factory Method)模式,又称多态性工厂(Polymorphic Factory)模
式或虚拟构造子(Virtual Constructor)模式;

二、工厂方法模式角色与结构
    抽象工厂(Creator)角色:是工厂方法模式的核心,与应用程序无关。任何在模式中创建的对象的工厂类必须实现这个接口。
  具体工厂(Concrete Creator)角色:这是实现抽象工厂接口的具体工厂类,包含与应用程序密切相关的逻辑,并且受到应用程序调用以创建产品对象。在上图中有两个这样的角色:BulbCreator与TubeCreator。
  抽象产品(Product)角色:工厂方法模式所创建的对象的超类型,也就是产品对象的共同父类或共同拥有的接口。在上图中,这个角色是Light。
  具体产品(Concrete Product)角色:这个角色实现了抽象产品角色所定义的接口。某具体产品有专门的具体工厂创建,它们之间往往一一对应。


三、创建过程如下

     一个工厂创建一个产品,所有的具体工厂继承自一个抽象工厂接口。
    客户端先创建不同产品的工厂,再由工厂创建具体产品,产品的创建逻辑分散在每个具体工厂类中。
    客户端只依赖于抽象工厂与抽象产品,不依赖任何具体的工厂与具体产品
    增加新产品时,需要增加工厂类和产品类,符合OCP原则

 

四、一个简单的实例   

Java代码 复制代码
  1. // 产品 Plant接口   
  2. public interface IPlant { }   
  3. //具体产品PlantA,PlantB   
  4. public class PlantA implements IPlant {   
  5.   
  6.  public PlantA () {   
  7.   System.out.println("create PlantA !");   
  8.  }   
  9.   
  10.  public void doSomething() {   
  11.   System.out.println(" PlantA do something ...");   
  12.  }   
  13. }   
  14. public class PlantB implements IPlant {   
  15.  public PlantB () {   
  16.   System.out.println("create PlantB !");   
  17.  }   
  18.   
  19.  public void doSomething() {   
  20.   System.out.println(" PlantB do something ...");   
  21.  }   
  22. }   
  23. // 工厂方法接口   
  24. public interface IFactory {   
  25.  public IPlant createPlant();   
  26. }   
  27. //具体工厂方法   
  28. public class FactoryA implements IFactory {   
  29.  public IPlant createPlant() {   
  30.   return new PlantA();   
  31.  }   
  32. }   
  33. public class FactoryB implements IFactory {   
  34.  public IPlant createPlant() {   
  35.   return new PlantB();   
  36.  }   
  37. }      
  38.   
  39. //客户端   
  40.   
  41. IFactory plantFactory = new FactoryA();   
  42.   
  43. IPlant planta = plantFactory.createPlant();   
  44.   
  45.  planta.doSomething();   
  46.   
  47.     
  48.   
  49. //若增加新产品PlantC时,只需要增加FactoryC工厂类和PlantC产品类即可。  
// 产品 Plant接口
public interface IPlant { }
//具体产品PlantA,PlantB
public class PlantA implements IPlant {

 public PlantA () {
  System.out.println("create PlantA !");
 }

 public void doSomething() {
  System.out.println(" PlantA do something ...");
 }
}
public class PlantB implements IPlant {
 public PlantB () {
  System.out.println("create PlantB !");
 }

 public void doSomething() {
  System.out.println(" PlantB do something ...");
 }
}
// 工厂方法接口
public interface IFactory {
 public IPlant createPlant();
}
//具体工厂方法
public class FactoryA implements IFactory {
 public IPlant createPlant() {
  return new PlantA();
 }
}
public class FactoryB implements IFactory {
 public IPlant createPlant() {
  return new PlantB();
 }
} 	

//客户端

IFactory plantFactory = new FactoryA();

IPlant planta = plantFactory.createPlant();

 planta.doSomething();

 

//若增加新产品PlantC时,只需要增加FactoryC工厂类和PlantC产品类即可。
 

此外,还有一个数字的加减乘除例子


五、工厂方法模式与简单工厂模式

  工厂方法模式与简单工厂模式再结构上的不同不是很明显。工厂方法类的核心是一个抽象工厂类,而简单工厂模式把核心放在一个具体类上。

  工厂方法模式之所以有一个别名叫多态性工厂模式是因为具体工厂类都有共同的接口,或者有共同的抽象父类。

  当系统扩展需要添加新的产品对象时,仅仅需要添加一个具体对象以及一个具体工厂对象,原有工厂对象不需要进行任何修改,也不需要修改客户端,很好的符合了"开放-封闭"原则。而简单工厂模式在添加新产品对象后不得不修改工厂方法,扩展性不好。

  工厂方法模式退化后可以演变成简单工厂模式

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值