模板方法模式
模板方法模式:定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
AbstractClass是抽象类,其实也是一个抽象模板,定义并实现了一个模板方法(templateMethod)。这个模板方法一般是一个具体方法,它给出了一个顶级逻辑的骨架,而逻辑的组成步骤在相应的抽象操作中(primitiveOperation1,primitiveOperation1),推迟到子类实现。顶级逻辑也可能调用一些具体方法。
ConcreteClass 子类,实现父类所定义的抽象方法。每一个AbstractClass都可以有任意多个ConcreteClass与之对应。而每一个ConcreteClass都可以给出这些抽象方法的不同实现,从而使得顶级逻辑的实现各不相同。
模板方法抽象类
abstract class AbstractClass {
//模板方法
public void templateMethod() {
//写一些可以被子类共享的代码
this.primitiveOperation1();
this.primitiveOperation2();
}
public abstract void primitiveOperation1(); //子类个性的行为,放到子类去实现
public abstract void primitiveOperation2(); //子类个性的行为,放到子类去实现
}
具体类,实现模板类中的抽象方法。
//模板方法具体类A
class ConcreteClassA extends AbstractClass {
public void primitiveOperation1(){
System.out.println("具体类A方法1实现");
}
public void primitiveOperation2(){
System.out.println("具体类A方法2实现");
}
}
//模板方法具体类B
class ConcreteClassB extends AbstractClass {
public void primitiveOperation1(){
System.out.println("具体类B方法1实现");
}
public void primitiveOperation2(){
System.out.println("具体类B方法2实现");
}
}
客户端
public class Test {
public static void main(String[] args){
System.out.println("**********************************************");
System.out.println("《大话设计模式》代码样例");
System.out.println();
AbstractClass classA = new ConcreteClassA();
// ConcreteClassA 实现了组成步骤的具体方法
classA.templateMethod();
AbstractClass classB = new ConcreteClassB();
// ConcreteClassB 实现了组成步骤的具体方法
classB.templateMethod();
System.out.println();
System.out.println("**********************************************");
}
}
考试题目
有一个考试试题和两个答题的学生。
TestPaper 为试题类。
TestPaperA,TestPaperB为两个学生类。
考题试卷类
abstract class TestPaper {
//试题1
public void testQuestion1() {
System.out.println(" 杨过得到,后来给了郭靖,炼成倚天剑、屠龙刀的玄铁可能是[ ] "+
" a.球磨铸铁 b.马口铁 c.高速合金钢 d.碳素纤维 ");
System.out.println("答案:"+this.answer1());
}
protected abstract String answer1();
//试题2
public void testQuestion2() {
System.out.println(" 杨过、程英、陆无双铲除了情花,造成[ ] "+
"a.使这种植物不再害人 b.使一种珍稀物种灭绝 c.破坏了那个生物圈的生态平衡" +
"d.造成该地区沙漠化 ");
System.out.println("答案:"+this.answer2());
}
protected abstract String answer2()
//试题3
public void testQuestion3() {
System.out.println(" 蓝凤凰致使华山师徒、桃谷六仙呕吐不止,如果你是大夫,"+
" 会给他们开什么药[ ] "+
"a.阿司匹林 b.牛黄解毒片 c.氟哌酸 d.让他们喝大量的生牛奶 e.以上全不对 ");
System.out.println("答案:"+this.answer3());
}
protected abstract String answer3();
}
学生A
class TestPaperA extends TestPaper {
//试题1
protected String answer1() {
return "b";
}
//试题2
protected String answer2() {
return "a";
}
//试题3
protected String answer3() {
return "c";
}
}
学生B 答的试卷
class TestPaperB extends TestPaper {
//试题1
protected String answer1() {
return "d";
}
//试题2
protected String answer2() {
return "b";
}
//试题3
protected String answer3() {
return "a";
}
}
在 TestPaper 类中有 testQuestion1,testQuestion2,testQuestion3,三个模板方法和 answer1,answer2,answer3 三个抽象方法,在模板方法中调用了抽象方法。
TestPaperA,TestPaperB 中分别实现了抽象方法。并给出不同的实现。
当我们要完成在某一细节层次一致的一个过程或一系列步骤,但其个别步骤在更详细的层次上的实现可能不同时,我们通常考虑用模板方法模式来处理。
模板方法模式总结
模板方法是把相同的公共的行为在抽象类中实现,在子类中针对具体的步骤给出不同的实现。
模板方法模式就是提供一个很好的代码复用平台。
当子类中不变的行为和可变的行为在方法中混合在一起的时候。不变的行为就会在子类中重复出现。我们可以通过模板方法模式,把不变的行为抽象到父类,帮助子类摆脱重复的不变行为的纠缠。