模版方法模式
当我们要完成在某一细节层次一致的一个过程或一系列步骤,但其个别步骤在更详细的层次上的实现可能不同时,我们通常考虑用模版方法模式来处理。
模版方法模式,定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模版方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
AbstractClass是抽象类,其实也就是一抽象模版,定义并实现了一个模版方法。这个模版方法一般是一个具体方法,它给出了一个顶级逻辑的骨架,而逻辑的组成步骤在相应的抽象操作中,推迟到子类实现。
abstract class AbstractClass
{
public abstract void PrimitiveOperation1();
public abstract void PrimitiveOperation2();
public void TemplateMethod()
{
PrimitiveOperation1();
PrimitiveOperation2();
System.err.println();
}
}
ConcreteClass 实现父类所定义的一个或多个抽象方法。每一个AbstractClass都可以有任意多个ConcreateClass与之对应,而每一个ConcreteClass 都可以给出这些抽象方法(顶级逻辑的组成步骤)的不同实现,从而使得顶级逻辑的实现各不相同。
class ConcreteClassA extends AbstractClass
{
public void PrimitiveOperation1()
{
//与ConcreteClassB不同的方法实现
System.err.println("具体类A方法1实现");
}
public void PrimitiveOperation2()
{
System.err.println("具体类A方法2实现");
}
}
class ConcreteClassB extends AbstractClass
{
public void PrimitiveOperation1(){
System.err.println("具体类B方法1实现");
}
public void PrimitiveOperation2(){
System.err.println("具体类B方法2实现");
}
}
客户端调用
static void Main(String[] args)
{
AbstractClass c;
c = new ConcreteClassA();
c.TemplateMethod();
c = new ConcreteClassB();
c.TemplateMethod();
}
模版方法模式特点
模版方法模式是通过把不变行为搬移到超类,去除子类中的重复代码来体现它的优势。
模版方法模式就是提供了一个很好的代码复用平台。
当不变的和可变的行为在方法的子类实现中混合在一起的时候,不变的行为就会在子类中重复出现。我们通过模版方法模式把这些行为搬移到单一的地方,这样就帮助子类摆脱重复的不变行为的纠缠。
模版方法模式是很常用的模式,在Java类库的设计中,通常都会利用模版方法模式提取类库中的公共行为到抽象类中。