模板方法模式:
模板方法模式,定义一个操作中的算法的骨架,而将一些步骤延迟到子类。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
AbstractClass是抽象类,其实也就是一抽象模板,定义并实现了一个模板方法。这个模板方法一般是一个具体方法,它给出了一个顶级逻辑的骨架,而逻辑的组成步骤在相应的抽象操作中,推迟到子类实现,顶级逻辑也有可能调用一些具体方法。
ConcreteClass,实现父类所定义的一个或多个抽象方法。每一个AbstractClass都可以有任意多个ConcreteClass与之对应,而每一个ConcreteClass都可以给出这些抽象方法(也就是顶级逻辑的组成步骤)的不同实现,从而使得顶级逻辑的实现各不相同。
代码:
#include<iostream>
usingnamespace std;
classAbstractClass
{
public:
virtual void PrimitiveOperation1()=0;
virtual void PrimitiveOperation2()=0;
void TemplateMethod()
{
PrimitiveOperation1();
PrimitiveOperation2();
cout<<"模板方法"<<endl;
}
};
classConcreteClassA :virtual public AbstractClass
{
public:
void PrimitiveOperation1()
{
cout<<"具体A类的函数实现1"<<endl;
}
void PrimitiveOperation2()
{
cout<<"具体A类的函数实现2"<<endl;
}
};
classConcreteClassB :virtual public AbstractClass
{
public:
void PrimitiveOperation1()
{
cout<<"具体B类的函数实现1"<<endl;
}
void PrimitiveOperation2()
{
cout<<"具体B类的函数实现2"<<endl;
}
};
intmain()
{
AbstractClass *p=NULL,*q=NULL;
ConcreteClassA CA;
p=&CA;
p->TemplateMethod();
ConcreteClassB CB;
q=&CB;
q->TemplateMethod();
return 0;
}
总结:
模板方法模式是通过把不变行为搬移到超类,除去子类中的重复代码来体现它的优势。
模板方法模式就是提供了一个很好的代码复用平台。当不变的和可变的行为在方法的子类实现中混合在一起时候,不变的行为就会在子类中重复出现,我们通过模板方法模式把这些行为搬移到单一的地方,这样就帮助子类摆脱重复的不变行为的纠缠。