设计模式-模板方法模式

模板方法模式定义:定义一个操作中的算法骨架,而把一些步骤延迟到子类中。模板方法模式可以让子类不改变一个算法的结构就可以改变算法的某些特定步骤。

说明:有时候,我们经常遇到由一些列步骤构成的过程需要执行,这个过程从高层看是相同的,但有些步骤的实现可能不同,这个时候可以考虑模板方法模式。

其结构图如下:


设计实例(抄试卷):

#include <iostream>
using namespace std;

class TestPaper
{
public:
	virtual char getAnswer1(void)=0;
	virtual char getAnswer2(void)=0;
	virtual char getAnswer3(void)=0;
	void TestQuestion1()
	{
		cout<<"这是题目一,请输入答案:";
		cout<<getAnswer1()<<endl;
	}
	void TestQuestion2()
	{
		cout<<"这是题目二,请输入答案:";
		cout<<getAnswer2()<<endl;
	}
	void TestQuestion3()
	{
		cout<<"这是题目三,请输入答案:";
		cout<<getAnswer3()<<endl;
	}
};

class TestPaperA:public TestPaper
{
	char getAnswer1()
	{
		return 'A';
	}
	char getAnswer2()
	{
		return 'B';
	}
	char getAnswer3()
	{
		return 'C';
	}
};

class TestPaperB:public TestPaper
{
	char getAnswer1()
	{
		return 'B';
	}
	char getAnswer2()
	{
		return 'C';
	}
	char getAnswer3()
	{
		return 'D';
	}
};

void main()
{
	TestPaperA testA;
	TestPaperB testB;

	cout<<"学生A的试卷:\r\n";
	testA.TestQuestion1();
	testA.TestQuestion2();
	testA.TestQuestion3();

	cout<<endl<<endl;

	cout<<"学生B的试卷:\r\n";
	testB.TestQuestion1();
	testB.TestQuestion2();
	testB.TestQuestion3();
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值