工厂方法模式(Factory Method),定义一个用于创建对象的接口,让子类决定实例化哪一个类。工厂方法使一个类的实例化延迟到了其子类。
在工厂方法模式中,工厂父类负责定义创建产品对象的公共接口,而工厂子类则负责生成具体的产品对象,这样做的目的是将产品类的实例化操作延迟到工厂子类中完成,即通过工厂子类来确定究竟应该实例化哪一个具体产品类。
工厂方法模式是简单工厂模式的进一步抽象和推广,简单工厂模式在《设计模式-改进策略模式-策略模式与简单工厂模式结合(Java)》 这篇Blog中使用过,也很容易理解。由于使用了面向对象的多态性,工厂方法模式保持了简单工厂模式的优点,而且克服了它的缺点(不符合“开闭原则”)。在工厂方法模式中,核心的工厂类不再负责所有产品的创建,而是将具体创建工作交给子类去做。这个核心类仅仅负责给出具体工厂必须实现的接口,而不负责哪一个产品类被实例化这种细节,这使得工厂方法模式可以允许系统在不修改工厂角色的情况下引进新产品。
我们举一个计算器的栗子,大家就能很快理解了。
//package com.dlut.designpattern.factory;
public abstract class Calculation {
int numberA;
int numberB;
public abstract double getResult();
}
class Add extends Calculation{
@Override
public double getResult() {
return numberA+numberB;
}
}
class Sub extends Calculation{
@Override
public double getResult() {
return numberA-numberB;
}
}
abstract class CalculationFactory{
public abstract Calculation createCalculation();
}
class AddFactory extends CalculationFactory{
@Override
public Calculation createCalculation() {
return new Add();
}
}
class SubFactory extends CalculationFactory{
@Override
public Calculation createCalculation() {
return new Sub();
}
}
测试类:
//package com.dlut.designpattern.factory;
public class Test {
public static void main(String[] args) {
CalculationFactory cf=new AddFactory();
Calculation c=cf.createCalculation();
c.numberA=2;
c.numberB=1;
System.out.println("Result:"+c.getResult());
cf=new SubFactory();
c=cf.createCalculation();
c.numberA=2;
c.numberB=1;
System.out.println("Result:"+c.getResult());
}
}
结果可想而知,在工厂方法模式中,我们需要记住四个角色,分别是:抽象产品,具体产品,抽象工厂,具体工厂,如果你能迅速地在代码中找到它们,就表明你对工厂方法的理解已经差不多了。
参考: