模板方法模式的定义
定义一个操作中的算法对象的骨架(稳定),而将一些步骤延迟到子类(定义一个虚函数,让子类去实现),template method使得子类可以不改变(复用)一个算法结构即可重定义该算法的某些步骤。
在理解模板方法模式的时候,我们需要先来看两个例子。
例子一:
假设有两种工作人员,一种程序库开发人员,一种是应用程序开发人员,应用程序开发人员需要去调用程序库开发人员实现的程序库。
在程序库中,step1,step3,step4是稳定的,应用程序开发人员直接调用即可,但是step2,step5步骤是不稳定的,需要应用程序开发人员根据需求变化去实现。但是 应用程序 的实现过程中,调用程序库的 整体结构 是稳定的,每种程序开发,它们调用step1,step2,step3,step4,step5的整体结构是不变的。第一种实现是程序库开发人员只实现step1,step3,step4,应用程序开发人员实现step4,step5和整体结构。
整体如下:
例子二:
由于应用程序 的实现过程中,调用程序库的 整体结构 是稳定的,所以程序库开发人员就定义一个run方法去实现整体结构,step2,step5是不稳定,所以就设定为虚函数,由应用程序开发人员进行重写。应用程序开发人员只需要实现step2,step5即可,不需要设计整体结构。
- 操作中的算法对象的骨架(稳定)就是Library类中的run方法,如果run整体结构不稳定,则模板方法是没有用的.
- step2,step5步骤是不稳定,可能根据不同应用需求实现的方式不稳定,所以将他们定义为虚函数,如果这两个步骤都是稳定的,那么模板方法是无效的,因为它不需要子类去重新定义这两个方法,即不许要去定义为虚函数
- 应用程序开发人员只需要实现变化的步骤即可,整体结构则不需要重新设计。