模板方法定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
结构
AbstractClass是抽象类,其实也就是一个抽象模板,定义并实现了一个模板方法。这个模板方法一般是一个具体方法,它给出了一个顶级逻辑的骨架,而逻辑的组成步骤在相应的抽象操作中,推迟到子类实现。代码如下:
ConcreteClass,实现父类所定义的一个或多个抽象方法。每一个AbstractClass都可以有任意多个ConcreteClass与之对应,而每一个ConcreteClass都可以给出这些抽象方法(也就是顶级逻辑的组成步骤)的不同实现,从而使得顶级逻辑的实现各不相同。代码如下:
模板方法使所有的重复的代码都要上升到父类去,而不是让每个子类都去重复。
当我们要完成在某一细节层次一致的一个过程或一系列步骤,但其个别步骤在更详细的层次上的实现可能不同时,我们通常用模板方法模式来处理。
示例
模板方法因为定义了一个操作中算法的骨架,所以,可以看成是先把算法结合起来,然后一同调用。
例如,早上我们起床的过程:先睁开眼睛,然后整理床铺,然后洗漱。可能在具体的实现细节上每个人会有不同,但是步骤是一样的。现在,我们用代码来描述这个过程:
namespace 起床模板 { abstract class AbsGetUp { public abstract void OpenEyes(); //睁开眼睛 public abstract void MakeBed(); //叠被子 public abstract void Wash(); //洗漱 public void TemplateMethod() { OpenEyes(); MakeBed(); Wash(); Console.WriteLine("起床成本,本次起床,击败了全国0%的用户,请再接再厉。"); } } //Vac起床 class Vac:AbsGetUp { public override void OpenEyes() { Console.WriteLine("Vac每天从她200多平方米的床上睁开眼睛。。。"); } public override void MakeBed() { Console.WriteLine("vac的200多个女仆正在给她叠被子呢。。"); } public override void Wash() { Console.WriteLine("vac正在一个200多平的大洗手间内刷牙。。"); } } //Jay起床 class Jay:AbsGetUp { public override void OpenEyes() { Console.WriteLine("jay大人睁开眼睛,听到了自己唱的《夜曲》"); } public override void MakeBed() { Console.WriteLine("jay大人的母亲一遍帮Jay叠被子,一边催他快一点而,fans都在门口。"); } public override void Wash() { Console.WriteLine("jay先有了个泳,然后去洗漱。"); } } class Program { static void Main(string[] args) { AbsGetUp vac = new Vac(); vac.TemplateMethod(); Console.WriteLine(" "); AbsGetUp jay = new Jay(); jay.TemplateMethod(); Console.WriteLine(" "); } } }
运行后,如图:
嘿嘿,还是挺好玩儿的。。。