Template Method lets subclassess redefine certain steps of an algorithm without changing
the algorithm's structure. 定义一个操作中的算法框架,而将一些步骤延迟到子类中。使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤抽象模板中的方法分两类: 基本方法:也叫基本操作,是由子类实现的方法,并且在模板方法中被调用。 模板方法:可以有一个或几个,一般是一个具体的方法,也就是一个框架,实现对基本方法的调度,完成固定的逻辑。 【为了防止恶意的操作,一般模板方法都加上final关键字,不允许被覆写】//抽象模板类 public abstract class AbstractClass{ //基本方法 protected abstract void doSomething(); //基本方法 protected abstract void doAnything(); //模板方法 public void templateMethod(){ //调用基本方法,完成相关逻辑 this.doAnything(); this.doSomething(); } } public class ConcreteClass1 extends AbstractClass{ protected void doAnything(){ .... } protected void doSomething(){ .... } } public class ConcreteClass2 extends AbstractClass{ protected void doAnything(){ ... } protected void doSomething(){ ... } } public class Client{ public static void main(String[] args){ AbstractClass class1=new ConcreteClass1(); AbstractClass class2=new ConcreteClass2(); class1.templateMethod(); class2.templateMethod(); } }
模板方法模式的优点:
1.封装不变部分,扩展可变部分:把认为不变的部分封装到父类中实现,而可变部分则可以通过继承来扩展 2.提取公共部分的代码,便于维护 3.行为有父类控制,子类主管实现:基本方法是有子类实现,因此子类可以通过扩展的方式增加相应的功能,符合开闭原则缺点:按正常的设计习惯,抽象类负责声明最抽象,最一般的事物属性和方法,实现完成具体的事物属性和方法。但是模板方法模式却是在抽象类中定义了部分抽象方法,由子类来实现,并且子类执行的结果会影响到父类的结构。使用场景:
1.多个子类有共同的方法,并且逻辑基本相同时 2.在重要,复杂的算法中,可以把核心算法设计为模板方法,周边相关的细节功能则由各个子类实现 3.重构时,模板方法经常用到,把相同的代码抽象到父类中,然后通过钩子函数约束其行为