简介
定义一个操作中算法的骨架,而将一些步骤延迟到子类中,模板方法使得子类可以不改变算法的结构即可重定义该算法的某些特定步骤。
代码
#include<iostream>
using namespace std;
class Abstract
{
public:
void show()
{
opera1();
opera2();
}
virtual void opera1(){}
virtual void opera2(){}
};
class A:public Abstract
{
void opera1()
{
cout<<"A实现方法1"<<endl;
}
void opera2()
{
cout<<"A实现方法2"<<endl;
}
};
class B:public Abstract
{
void opera1()
{
cout<<"B实现方法1"<<endl;
}
void opera2()
{
cout<<"B实现方法2"<<endl;
}
};
int main()
{
Abstract *abs;
abs = new A;
abs->show();
abs = new B;
abs->show();
system("pause");
return 0;
}
总结
通俗点的理解就是 :完成一件事情,有固定的数个步骤,但是每个步骤根据对象的不同,而实现细节不同;就可以在父类中定义一个完成该事情的总方法,按照完成事件需要的步骤去调用其每个步骤的实现方法。每个步骤的具体实现,由子类完成。