#include <iostream>
#include <string>
using namespace std;
///所有重复的代码都应该要上升到父类去,而不是让每个子类都去重复
///模板方法模式:定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤
///模板方法模式是通过把不变行为搬移到超类,去除子类中的重复代码来体现它的优势
///模板方法模式就是提供了一个很好的代码复用的平台。因为有时候,我们会遇到由一系列步骤构成的过程需要执行。这个过程从高层次上看是相同的,但有些步骤的实现可能不同
///当不变的和可变的行为在方法的子类的实现中混合在一起的时候,不变的行为就会在子类中重复出现。我们通过模板方法模式把这些行为搬移到单一的地方,这样就帮助子类摆脱重复的不变的行为的纠缠
class TestPaper
{
public:
void TestQuestion1()
{
cout << "1111111111111" << endl;
cout << Answer1() << endl;
}
void TestQuestion2()
{
cout << "2222222222222" << endl;
cout << Answer2() << endl;
}
void TestQuestion3()
{
cout << "3333333333333" << endl;
cout << Answer3() << endl;
}
///关键是这三个虚函数,由子类实现各自不同的功能
virtual string Answer1()
{
return "";
}
virtual string Answer2()
{
return "";
}
virtual string Answer3()
{
return "";
}
};
class TestPaperA : public TestPaper
{
public:
virtual string Answer1()
{
return "a";
}
virtual string Answer2()
{
return "b";
}
virtual string Answer3()
{
return "c";
}
};
class TestPaperB : public TestPaper
{
public:
virtual string Answer1()
{
return "c";
}
virtual string Answer2()
{
return "b";
}
virtual string Answer3()
{
return "a";
}
};
int main()
{
///用基类指针指向子类对象
TestPaper* test1 = new TestPaperA;
test1->TestQuestion1();
test1->TestQuestion2();
test1->TestQuestion3();
delete test1;
TestPaper* test2 = new TestPaperB;
test2->TestQuestion1();
test2->TestQuestion2();
test2->TestQuestion3();
delete test2;
return 0;
}