Template Method模式和Strategy模式都可以用来分离高层的算法和低层的具体实现。都运行高层的算法独立于它的具体实现细节重用。Streategy模式也运行具体实现细节独立于高层的算法重用,不过是要以一些额外的复杂性、内存以及运行时间开销为代价。
Template Method模式使用继承和override或者抽象类,Strategy使用委托来达到分离通用的算法或处理和具体的上下文。
Template Method模式在父类(可以为抽象类)中写通用的应用功能或算法,具体的算法实现或者通用功能上的扩展在具体的子类完成。子类通过实现父类的抽象方法,或者通过override父类的方法来扩展父类的功能或者是进行具体的算法实现。
继承是一种非常强的关系,派生类不可避免的要和它们的基类绑定在一块。
Strategy模式不是将通用功能和算法放到一个通用的抽象或非抽象基类,而是放到一个具体的实现类中ApplicationRunner,把通用算法必须要调用的方法定义在接口Application中,由这个接口派生出ApplicationStrategy,并将它传给ApplicationRunner。之后,ApplicationRunner就可以把具体的工作委托给这个接口来完成。
这样具体的实现就可以不用绑定到算法ApplicationRunner了。但是Strategy模式比Template Method涉及到更多数量的类和间接层次,以及比继承稍微多点的运行时间和数据空间开销。
Template Method模式使用继承和override或者抽象类,Strategy使用委托来达到分离通用的算法或处理和具体的上下文。
Template Method模式在父类(可以为抽象类)中写通用的应用功能或算法,具体的算法实现或者通用功能上的扩展在具体的子类完成。子类通过实现父类的抽象方法,或者通过override父类的方法来扩展父类的功能或者是进行具体的算法实现。
继承是一种非常强的关系,派生类不可避免的要和它们的基类绑定在一块。
Strategy模式不是将通用功能和算法放到一个通用的抽象或非抽象基类,而是放到一个具体的实现类中ApplicationRunner,把通用算法必须要调用的方法定义在接口Application中,由这个接口派生出ApplicationStrategy,并将它传给ApplicationRunner。之后,ApplicationRunner就可以把具体的工作委托给这个接口来完成。
这样具体的实现就可以不用绑定到算法ApplicationRunner了。但是Strategy模式比Template Method涉及到更多数量的类和间接层次,以及比继承稍微多点的运行时间和数据空间开销。