模板方法模式,定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定的步骤。当我们要完成在某一细节层次一致的一个过程或一系列步骤,但其个别步骤在更详细的层次上的实现可能不同时,我们通常考虑用模板方法模式来处理。
AbstractClas是抽象类,其实也就是一抽象模板,定义并实现了一个模板方法。这个模板方法一般是一个具体方法,它给出了一个顶级逻辑的骨架,而逻辑的组成步骤在相应的抽象操作中,推迟到子类实现。顶级逻辑也有可能调用一些具体方法。
class AbstractClass { public: /*一些抽象行为,放到子类去实现*/ virtual void PrimitiveOperation1()=0; virtual void PrimitiveOperation2()=0; /*模板方法,给出了逻辑骨架,而逻辑的组成是一些相应的抽象操作,它们都推迟到子类实现*/ void TemplateMethod() { PrimitiveOperation1(); PrimitiveOperation2(); } };
ConcreteClass,实现父类所定义的一个或多个抽象方法。每个AbstractClass都可以有任意多个ConcreteClass与之对应,而每一个ConcreteClass都可以给出这些抽象方法(也就是顶级逻辑的组成步骤)的不同实现,从而使得顶级逻辑的实现各不相同。
class ConcreteClassA:public AbstractClass { public: void PrimitiveOperation1() { cout << "具体类A方法1实现" << endl; } void PrimitiveOperation2() { cout << "具体类A方法2实现" << endl; } }; class ConcreteClassB:public AbstractClass { public: void PrimitiveOperation1() { cout << "具体类B方法1实现" << endl; } void PrimitiveOperation2() { cout << "具体类B方法2实现" << endl; } };
主程序调用:
int main() { AbstractClass *c; c=new ConcreteClassA(); c->TemplateMethod(); c=new ConcreteClassB(); c->TemplateMethod(); return 0; }
模板方法模式是通过把不变行为搬移到超类,去除子类中重复代码来体现它的优势,也就是提供了一个很好的代码复用平台。总之,当不变的和可变的行为在方法的子类实现中混合在一起的时候,不变的行为就会在子类中重复出现,通过模板方法模式把这些行为搬移到单一的地方,这样就帮助子类摆脱重复的不变行为的纠缠。
原文:http://www.cnblogs.com/awy-blog/p/3811217.html