1、思想
定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重新定义该算法的某些特定步骤。
2、代码实现
package 测试;
abstract class AbstractClass{
public abstract void PrimitiveOperation1();
public abstract void PrimitiveOperation2();
public void TemplateMethod(){
PrimitiveOperation1();
PrimitiveOperation2();
}
}
class ConcreteClassA extends AbstractClass{
@Override
public void PrimitiveOperation1() {
// TODO Auto-generated method stub
System.out.println("具体类A方法1实现");
}
@Override
public void PrimitiveOperation2() {
// TODO Auto-generated method stub
System.out.println("具体类A方法2实现");
}
}
class ConcreteClassB extends AbstractClass{
@Override
public void PrimitiveOperation1() {
// TODO Auto-generated method stub
System.out.println("具体类B方法1实现");
}
@Override
public void PrimitiveOperation2() {
// TODO Auto-generated method stub
System.out.println("具体类B方法2实现");
}
}
public class Main5{
public static void main(String [] args){
AbstractClass c;
c = new ConcreteClassA();
c.TemplateMethod();
c = new ConcreteClassB();
c.TemplateMethod();
}
}
运行结果:
具体类A方法1实现
具体类A方法2实现
具体类B方法1实现
具体类B方法2实现
3、结构图
4、模板方法模式的优点
模板方法模式是通过把不变行为搬移到父类,去除子类中的重复代码来体现它的优势。模板方法模式就是提供了一个很好的代码复用平台。
当不变的和可变的行为在方法的子类实现中混合在一起的时候,不变的行为就会在子类中重复出现。我们通过模板方法模式把这些行为搬移到单一的地方,这样就帮助子类摆脱重复的不变行为的纠缠。