设计模式------模板方法模式

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

模板方法模式是通过把不变行为搬移到超类,去除子类中重复代码,以体现它的优势。模板方法模式提供了一个很好的代码复用平台。所以,当不变和可变的行为在方法的子类实现中混合在一起的时候,不变的行为就会在子类中重复出现。我们通过模板方法模式把这些行为搬移到单一的地方,这样就帮助子类摆脱重复的不变行为的纠缠。

例子:

class testpaper
{
	public  String Answer1()
	{
		return "";
	}
	public  String Answer2()
	{
		return "";
	}
	public  String Answer3()
	{
		return "";
	}
	public void question1()
	{
		System.out.println("第一个问题你选啥?");
		System.out.println("第一个问题我选: "+Answer1());
	}
	public void question2()
	{
		System.out.println("第二个问题你选啥?");
		System.out.println("第二个问题我选: "+Answer2());
	}
	public void question3()
	{
		System.out.println("第三个问题你选啥?");
		System.out.println("第三个问题我选: "+Answer3());
	}
}
class student1 extends testpaper
{
	public String Answer1()
	{
		return "A";
	}
	public String Answer2()
	{
		return "B";
	}
	public String Answer3()
	{
		return "C";
	}
}
class student2 extends testpaper
{
	public String Answer1()
	{
		return "C";
	}
	public String Answer2()
	{
		return "B";
	}
	public String Answer3()
	{
		return "A";
	}
}
public class template
{
	public static void main(String args[])
	{
		testpaper st1 = new student1();
		st1.question1();
		st1.question2();
		st1.question3();
		
		testpaper st2 = new student2();
		st2.question1();
		st2.question2();
		st2.question3();
	}

在主类testpaper中定义了三个函数,三个函数分别调用了类中步骤相关的三个虚函数,虚函数的实现在子类中重写,通过多态调用虚函数的不同实现方法,来梳理不同的事件步骤。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值