目录
一、工厂方法模式简介
简单工厂模式的改进版!
新增功能时不再修改工厂类了,而是通过实现工厂接口,每一种都由自己的工厂类实现。
工厂方法模式是一种常用的类创建型设计模式,此模式的核心精神是封装类中变化的部分,提取其中个性化善变的部分为独立类,通过依赖注入以达到解耦、复用和方便后期维护拓展的目的。
它的核心结构有四个角色,分别是抽象工厂;具体工厂;抽象产品;具体产品
二、Java实现
实现的功能和上一篇简单工厂模式的是一样的。
抽象工厂
public interface OperationFactory {
public Operation createFactory() ;
}
具体工厂
public class AddFactory implements OperationFactory {
@Override
public Operation createFactory() {
return new AddOperation();
}
}
public class SubFactory implements OperationFactory {
@Override
public Operation createFactory() {
return new SubOperation();
}
}
抽象产品
public interface Operation {
//执行操作
void performOperation(double... nums);
}
具体产品
和上一篇一样,加减法的具体实现
测试:
public class Test {
public static void main(String[] args) {
OperationFactory factory = new AddFactory();
Operation add = factory.createFactory();
add.performOperation(1,2,3);
OperationFactory factory2 = new SubFactory();
Operation sub = factory2.createFactory();
sub.performOperation(3,2,1);
}
}
结果:
1.0 + 2.0 + 3.0=6
3.0 - 2.0 - 1.0=0.0
三、模式应用
工厂方法经常用在以下两种情况中:
第一种情况是对于某个产品,调用者清楚地知道应该使用哪个具体工厂服务,实例化该具体工厂,生产出具体的产品来。Java Collection中的iterator() 方法即属于这种情况。
第二种情况,只是需要一种产品,而不想知道也不需要知道究竟是哪个工厂为生产的,即最终选用哪个具体工厂的决定权在生产者一方,它们根据当前系统的情况来实例化一个具体的工厂返回给使用者,而这个决策过程这对于使用者来说是透明的。
四、优缺点
优点:克服了简单工厂违背开放-封闭原则的缺点,又保留了封装对象创建过程的优点,降低客户端和工厂的耦合性,所以说“工厂模式”是“简单工厂模式”的进一步抽象和推广。
缺点:每增加一个产品,相应的也要增加一个子工厂,加大了额外的开发量。