Template Method:模板方法模式

  • Post author:
  • Post category:其他


模板方法模式即提供一个抽象基类作为模板类,用户直接使用此模板类。标准模板类可以被任意派生模板类代替。于是用户每次需要不同的处理方式时,仅需要更换派生模板,而不需要对模板的调用做任何修改。

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 版权协议,转载请附上原文出处链接和本声明。