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涉及到更多数量的类和间接层次,以及比继承稍微多点的运行时间和数据空间开销。
本文探讨了TemplateMethod模式和Strategy模式的区别与联系。这两种设计模式都能实现算法与实现的分离,但各自采用不同的方法:前者利用继承和覆盖,后者采用委托。文章详细解释了两种模式的具体应用方式及其优缺点。
4249

被折叠的 条评论
为什么被折叠?



