模版方法模式简介
定义
定义一个操作中的算法的骨架,而将一些步骤延迟到子类中,
模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤
典型描述
自己做饭吃的例子
父类定义
第一步:买菜
第二步:洗菜
第三步:做菜
第四步:吃菜
第五步:洗碗
子类定义
第一步:去那里买菜(父类不关心,买回来就成)
第二步:用什么洗菜(父类不关心,洗干净就成)
第三步:菜做的好不好(父类不关心,能做出来就成)
第四步:怎么吃菜(父类不关心,吃进肚子就成)
第五步:用什么洗碗(父类不关心,洗干净就成)
子类不能改变父类的步骤
使用场合
把不变的行为放在父类,把可变的行为留给子类来完成
各子类公共的行为应该被提取并集中到一个公共父类中以避免重复
控制子类的扩展
模版方法的组成部分
父类角色:提供模版
子类角色:为模版提供实现
模板方法模式案例
/*****************定义模版****************/
package com.itlwc;
/*
定义父类角色(模版)
模版内容
方法必须按顺序执行,method1,method2,method3
*/
public abstract class AbstractClass {
public abstract void method1();
public abstract void method2();
public abstract void method3();
// 定义骨架 (接口不能实现模版,因为接口不能有非抽象方法,导致不能定义模版的骨架)
public void template() {
this.method1();
this.method2();
this.method3();
}
}
/*****************为模版提供实现***************/
package com.itlwc;
/*
定义子类角色(为模版提供实现)
*/
public class ConcreteClass extends AbstractClass {
@Override
public void method1() {
System.out.println("执行方法一");
}
@Override
public void method2() {
System.out.println("执行方法二");
}
@Override
public void method3() {
System.out.println("执行方法三");
}
}
/**************测试类*******************/
package com.itlwc;
public class Test {
public static void main(String[] args) {
AbstractClass a = new ConcreteClass();
a.template();
}
}