模板方法模式即提供一个抽象基类作为模板类,用户直接使用此模板类。标准模板类可以被任意派生模板类代替。于是用户每次需要不同的处理方式时,仅需要更换派生模板,而不需要对模板的调用做任何修改。
1. 抽象模板类定义
抽象模板类规定了对外的标准接口及派生类需要实现的抽象接口。
对于用户而言,只需要使用标准接口。
//抽象模板
class AbstractClass
{
protected:
//一些抽象接口,放到子类中去实现
virtual void PrimitiveOperation1() = 0;
virtual void PrimitiveOperation2() = 0;
public:
//标准接口,规定了逻辑的骨架,具体的抽象操作推迟到子类中实现
void TemplateMethod()
{
this->PrimitiveOperation1();
this->PrimitiveOperation2();
};
};
2. 派生模板类定义
派生类会实现基类所定义的抽象方法。
不同派生类的实现不同。这样当调用标准接口时,所调用的实现也不同。
//实现基类所定义的抽象方法
class ConcreteClassA : public AbstractClass
{
public:
//实现基类定义的抽象行为
virtual void PrimitiveOperation1() {};
virtual void PrimitiveOperation2() {};
};
//实现基类所定义的抽象方法
class ConcreteClassB : public AbstractClass
{
public:
//实现基类定义的抽象行为
virtual void PrimitiveOperation1() {};
virtual void PrimitiveOperation2() {};
};
3. 用户使用
用户直接使用抽象模板类基类,然后创建派生类赋给基类。这样,虽然调用的是基类标准接口,但是根据赋给的派生类不同,会产生不同的效果。
void main()
{
//ConcreteClassA与ConcreteClassB可相互替换
AbstractClass* pAbstract = nullptr;
pAbstract = new ConcreteClassA();
pAbstract->TemplateMethod();
pAbstract = new ConcreteClassB();
pAbstract->TemplateMethod();
}
版权声明:本文为fyyyr原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。