模板方法模式:定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
模板方法模式是通过把不变行为搬移到超类,去除子类中重复代码,以体现它的优势。模板方法模式提供了一个很好的代码复用平台。所以,当不变和可变的行为在方法的子类实现中混合在一起的时候,不变的行为就会在子类中重复出现。我们通过模板方法模式把这些行为搬移到单一的地方,这样就帮助子类摆脱重复的不变行为的纠缠。
例子:
class testpaper
{
public String Answer1()
{
return "";
}
public String Answer2()
{
return "";
}
public String Answer3()
{
return "";
}
public void question1()
{
System.out.println("第一个问题你选啥?");
System.out.println("第一个问题我选: "+Answer1());
}
public void question2()
{
System.out.println("第二个问题你选啥?");
System.out.println("第二个问题我选: "+Answer2());
}
public void question3()
{
System.out.println("第三个问题你选啥?");
System.out.println("第三个问题我选: "+Answer3());
}
}
class student1 extends testpaper
{
public String Answer1()
{
return "A";
}
public String Answer2()
{
return "B";
}
public String Answer3()
{
return "C";
}
}
class student2 extends testpaper
{
public String Answer1()
{
return "C";
}
public String Answer2()
{
return "B";
}
public String Answer3()
{
return "A";
}
}
public class template
{
public static void main(String args[])
{
testpaper st1 = new student1();
st1.question1();
st1.question2();
st1.question3();
testpaper st2 = new student2();
st2.question1();
st2.question2();
st2.question3();
}
在主类testpaper中定义了三个函数,三个函数分别调用了类中步骤相关的三个虚函数,虚函数的实现在子类中重写,通过多态调用虚函数的不同实现方法,来梳理不同的事件步骤。